Logo

Programming-Idioms

This language bar is your friend. Select your favorite languages!
  • Perl

Idiom #30 Parallelize execution of 1000 independent tasks

Launch the concurrent execution of the procedure f with parameter i from 1 to 1000.
Tasks are independent and f(i) doesn't return any value.
Tasks need not run all at the same time, so you may use a pool.

use threads;
for my $i (1 .. 1000) {
    threads->create('f', $i);
}

Note: The threads library will warn you at the end of the program if you don't join or detach each thread.
(dorun (pmap f (range 1 1001)))

New implementation...