foreach

Steven Schveighoffer via Digitalmars-d digitalmars-d at puremagic.com
Thu Jun 12 20:42:40 PDT 2014


On Thu, 12 Jun 2014 23:34:27 -0400, Manu via Digitalmars-d  
<digitalmars-d at puremagic.com> wrote:

> On 13 June 2014 13:04, Daniel Murphy via Digitalmars-d
> <digitalmars-d at puremagic.com> wrote:
>>
>> i,j,k,etc work just fine.  Are you really nesting your loops that  
>> deeply?
>
> Giving explicit names pollutes the local namespace, and the point
> below about unreferenced variable warnings if you give explicit names.

i, j, k are traditionally loop variables. People have been using them for  
decades without conflicting their other variables.

>>
>> The compiler's optimizer will do that just fine.
>
> Not necessarily. The range might be a lib, and non-pure. The compiler
> can't optimise/inline/eliminate the call if it doesn't have code.
> In my experience this is common, I frequently wrap C api's in D-style
> ranges. Potentially a lot of unnecessary calls to
> C_API_GetItem(itemIndex).

2 options:

foreach(i; 0..r.walkLength)
{
}

or

while(!r.empty)
{
    r.popFront();
}

-Steve


More information about the Digitalmars-d mailing list