Beefy Boxes and Bandwidth Generously Provided by pair Networks
Problems? Is your data what you think it is?
 
PerlMonks  

Re: Re: Re: Re: Re: for loop localisation bug?

by BrowserUk (Pope)
on Dec 29, 2003 at 20:29 UTC ( #317541=note: print w/ replies, xml ) Need Help??


in reply to Re: Re: Re: Re: for loop localisation bug?
in thread for loop localisation bug?

Sorry, but I think you are wrong on this. Checking both K&R (the original version from circa. 1978) and the ANSI C specification, particularly Scopes of identifiers and Iteration statements, I can find nothing to support your position.

Identifiers in C are block scoped, the iterator variable in a for loop must be declared prior to the for loop and there is nothing special about it. It retains the last value set until that value is changed, regardless of whether the statement that changed it is a simple assignment, inside or outside of a loop body, or even as one of the three statements that make up the for loop control statements. It remains in scope and defined until the block at which it was defined is exited.

It is never undefined, and any such statement of 'best practice' is simply ignoring both the design specification and the realities of implementations. It buys you nothing.


Examine what is said, not who speaks.
"Efficiency is intelligent laziness." -David Dunham
"Think for yourself!" - Abigail
Hooray!


Comment on Re: Re: Re: Re: Re: for loop localisation bug?
Re: for loop localisation bug?(C For Loop)
by MADuran (Beadle) on Dec 29, 2003 at 21:24 UTC
    ANSI/ISO/IEC Standard 9899:1999 (C99 Standard) (Link to ANSI's Store) allows allocation of the identifer in the for statement and scopes the identifer to the loop only

    This code is now legal in C99 compilers (which to my knowledge there are not very many)

    for(int i=0; i < 100; i++){ /*do some thing with i */ printf("this is i: %d", i); }

    and it is lexically the same as:

    { int i; for(i=0; i < 100; i++){ /*do something here with i */ printf("this is i: %d", i); } }
    **This code is Not Tested (even for correctness)**
    Note that the second code sinpet is blocked, limiting the scope of i in the for statement. References are the Swedish Instute of Computer Science (which posted the C99 Standard here (a PDF) if this is not a legal posting please remove link)
    6.8.5.3 is the paragraph dealing with the FOR statement

    And this overview of C99

    This does NOT invalidate your argument about pre c99 compilers or non-complying compilers. And if you declare your iterator loop varable before the for loop it will work the same as it did previouly. I point this out because I think that this is what these other fine Monks must be thinking of.

    MADuran who must now find a spiffy sig.

Log In?
Username:
Password:

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

How do I use this? | Other CB clients
Other Users?
Others exploiting the Monastery: (4)
As of 2014-11-29 08:33 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    My preferred Perl binaries come from:














    Results (204 votes), past polls