each! vs foreach parallel timings

Ali Çehreli via Digitalmars-d-learn digitalmars-d-learn at puremagic.com
Sun Dec 27 15:42:57 PST 2015


On 12/27/2015 11:30 AM, Jay Norwood wrote:

 >      samples[].each!((int i, ref a)=>apply_metrics(i,a));

Are you using an older compiler? That tuple expansion does not work any 
more at least with dmd v2.069.0 but you can use enumerate():

         samples[].enumerate.each!(t=>apply_metrics(t[0].to!int,t[1]));

 >          foreach( i, ref a; parallel(samples[])){ apply_metrics(i,a);}

That does not compile because i is size_t but apply_metrics() takes an 
int. One solution is to call to!int:

         foreach( i, ref a; parallel(samples[])){ 
apply_metrics(i.to!int,a);}

To not answer your actual question, I don't think it's possible. :)

Ali



More information about the Digitalmars-d-learn mailing list