Re: Range-based for loops and existing variables
 
On 3 Nov., 19:42, Joe Gottman <jgott...@carolina.rr.com> wrote:
I was reading the proposal for the ranged-based for loop recently
accepted into c++0x
(http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2008/n2778.htm). If
I understand this proposal correctly, it is illegal to use an already
existing variable in the first part of this kind of loop.  Thus the
following code would be legal:
vector<int> vec;
for (int x : vec) { /* do whatever */ }
But this code would not be legal:
vector<int> vec;
int x = 0; // Declare x outside of loop
for ( x : vec) { /* do whatever */}
Am I correct in my reading of this paper?  If so, what is the reason for
making the second type of loop illegal?
I agree that both the N2778 paper and the current draft
N2798 do exclude your second type. I do not know whether
this outcome was intended or not, but I tend to say that I
have no convincing arguments in my pocket to justify
such an extension. This kind of loop has no loop-counter
in the classical meaning, so the only advantage I can
think of is to have the very last logical element referenced
(I mean logical in sense, that this is not necessarily the
last sequence element, but possibly one earlier due to
possible usage of jumps). If I want to simulate this, I
could either use the classical for-statement or I use a
helper variable. The last one can be cheap, if I can choose
a reference-type as type-specifier of the for-range-declaration,
e.g. in
vector<int> vec;
int x = 0; // Declare x outside of loop
for (const int& x2 : vec) {
   x = x2;
   /* do whatever */
}
I have used such for-each-style loops in Delphi, Java, and
C# before and never missed this reduced functionality.
Just my 2 Euro cents,
Daniel
-- 
      [ See http://www.gotw.ca/resources/clcm.htm for info about ]
      [ comp.lang.c++.moderated.    First time posters: Do this! ]