Share array element between threads
via Digitalmars-d-learn
digitalmars-d-learn at puremagic.com
Thu Nov 6 05:04:16 PST 2014
On Thursday, 6 November 2014 at 10:53:32 UTC, Misu wrote:
> Hi,
>
> when I execute this code I have 7 7 7 as result, I think I
> understand why.
>
> How can I execute a special task for one element ?
>
> import std.stdio;
> import std.parallelism;
>
> void main(string[] args)
> {
> class Account
> {
> public this(int id) { this.id = id; }
> int id;
> }
>
> Account[] accounts = [new Account(5), new Account(6), new
> Account(7)];
>
> foreach(acc; accounts)
> {
> task(() { writeln(acc.id); }).executeInNewThread();
> }
>
> readln();
> }
It's a bug: https://issues.dlang.org/show_bug.cgi?id=2043
As a workaround, you can nest the call in another lambda:
foreach(acc; accounts)
{
(Account acc) {
task(() { writeln(acc.id); }).executeInNewThread();
} (acc);
}
More information about the Digitalmars-d-learn
mailing list