http://www.perlmonks.org?node_id=445051


in reply to Re^5: Interview Prepration
in thread Interview Prepration

I don't know what's confusing about calling something what it is, especially when there's an authoritative source that most people should have already read, or will read now. In fact, I find it more confusing when people are inventing their own terms when perfectly good terms exist.

No, I'll stand by the reference docs here, unless I hear otherwise from the man himself.

-- Randal L. Schwartz, Perl hacker
Be sure to read my standard disclaimer if this is a reply.

Replies are listed 'Best First'.
Re^7: Interview Prepration
by Limbic~Region (Chancellor) on Apr 05, 2005 at 18:20 UTC
    merlyn,
    Let me preface my post by stating that I agree with most of what you are saying. I do think it is confusing to be able to use the keywords interchangeably but not have interchangeable behavior - regardless of it being documented. Since both the Camel and Llama are copyrighted, I will quote from perldoc perlsyn.

    The "foreach" keyword is actually a synonym for the "for" keyword, so you can use "foreach" for readability or "for" for brevity.

    I know that the rest of the documentation explains the distinct differences in the behavior (implicit aliasing and localizing), but how hard would it be to add:

    "Caution: While the keywords are interchangeable, the behavior of the looping constructs are not. What appears in the parens after the keywords determines the internal behavior".

    It certainly isn't your fault that most people don't carefully read the documentation nor is it mine. That doesn't negate the fact that it happens everyday. Taking that one snippet out of context would lead people to believe they are the same thing. Using the "Try It And See" method in a naive way supports this since interchanging for and foreach keywords results in identical behavior.

    In summary, it is my belief that that because the keywords are interchangeable and there are no big red warning flags in the documentation, people are going to incorrectly believe there is no difference.

    Cheers - L~R

Re^7: Interview Prepration
by adrianh (Chancellor) on Apr 06, 2005 at 08:52 UTC
    I don't know what's confusing about calling something what it is, especially when there's an authoritative source that most people should have already read, or will read now. In fact,

    I personally don't find it confusing - but I've come across many people who do. Since the for/foreach keywords can be used interchangable for for/foreach loops I don't find the confusion that odd.

    Having become bored with conversations that go:

    "You should use a foreach loop there"
    "I am"
    "No you're not"
    "Yes I am - look"
    <sound of Adrian gritting teeth> "I mean you're using a C-style for loop, why not just iterate over the container"
    "Oh - yeah"

    I tend to always call them "C-style for loops" to save myself the effort.