Beefy Boxes and Bandwidth Generously Provided by pair Networks
Welcome to the Monastery
 
PerlMonks  

Re: •Re: "for" surprise

by fletcher_the_dog (Friar)
on Nov 21, 2003 at 20:03 UTC ( [id://309033]=note: print w/replies, xml ) Need Help??


in reply to •Re: "for" surprise
in thread "for" surprise

Well, I had looked in the perldoc but I guess I was looking in the wrong place. Even so, I think this localization is very unDWIMy. Is there anyone out there who has been bitten by it? Is there anyway to get a warning about it? (I already tried -w and "use warnings")

Replies are listed 'Best First'.
•Re: Re: •Re: "for" surprise
by merlyn (Sage) on Nov 21, 2003 at 20:07 UTC
    Perhaps you forget that Perl is not DWIM, but DWLM (Do What Larry Means).

    Luckily, Larry has given us notes about what he wants Perl to do. {grin}

    Seriously, the localization is an important positive property of foreach loops, and something that while you may have just learned, has been a property of foreach loops since Perl version 1.

    Asking for a warning on the locallization there would be like getting a warning on an assignment operator because "the value of the variable has now changed!". No, not gonna happen. Sometimes, you have to think for yourself, and learn what there is to learn about the language.

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

Re: Re: •Re: "for" surprise
by Corion (Patriarch) on Nov 21, 2003 at 20:07 UTC

    Relying on the fact that the loop iterator has a defined value after leaving the loop is bad style in many languages, as many languages explicitly state the value of the loop iterator as undefined.

    Personally, I prefer to create loop iterators that are scoped only to the loop block, as that completely avoids the issue:

    for my $i (1..67) { ... };

    That way, $i can't be used outside the loop, and I consider that a good thing. But why are you using a loop over a fixed range instead of a loop from 1 to $end anyway?

    perl -MHTTP::Daemon -MHTTP::Response -MLWP::Simple -e ' ; # The $d = new HTTP::Daemon and fork and getprint $d->url and exit;#spider ($c = $d->accept())->get_request(); $c->send_response( new #in the HTTP::Response(200,$_,$_,qq(Just another Perl hacker\n))); ' # web
      That way, $i can't be used outside the loop, and I consider that a goo +d thing.
      I agree that makes sense and I do it myself all the time, but sometimes it might not be what you want to do and it might not be good thing in which case even if you think you are changing the behavior, you are not.
      But why are you using a loop over a fixed range instead of a loop from + 1 to $end anyway?
      It was a small example not real code. Where it says "# do some useful stuff" there would be ... some useful stuff :-)
        ...or, for that matter, why we have:
        for ($i=0; $i<53; $i++) { }
        loops, as well. Even though perl's list-iterating for-loops are incredibly sweet, and replace 99% of for-loops written in other languages, there's still that 1% of iterating loops that aren't list-iterating loops... and that's why perl still has for( ; ; ) loops as well.

        The real reason why the value is localized within the loop is that it is not the variable (by the same name) outside of the loop. Period. What it is, though, is an alias to the item in the list being iterated over. That is why you can do things like:

        foreach my $item (@list) { $item = mutate $item; }
        and it produces the same result as:
        @list = map { mutate $_ } @list;
        That is... in the nth iteration of the loop, the list-iterator variable IS the nth item in the array. They are one and the same.

        With that context in mind, ask yourself how much sense it would make that your list iterator variable was not localized.


        ------------
        :Wq
        Not an editor command: Wq
        but sometimes it might not be what you want to do
        That's why we have a while as well.

        Abigail

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://309033]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this?Last hourOther CB clients
Other Users?
Others surveying the Monastery: (5)
As of 2024-04-23 17:35 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found