resulted in the following measurement-output:my @data = (1..8000000); foreach my $x (@data) { push @arr, ($x+2); } @arr1 = map { $_+ 2 } @data; @arr2 = map { push @arr2, ($_+ 2) } @data;
Time taken by foreach loop was 2 wallclock secs ( 2.27 usr 0.03 sys + 0.00 cusr 0.00 csys = 2.30 CPU) seconds
Time taken by map block was 4 wallclock secs ( 3.39 usr 0.34 sys + 0.00 cusr 0.00 csys = 3.73 CPU) seconds
Time taken by map block (with push) was 5 wallclock secs ( 4.63 usr 0.05 sys + 0.00 cusr 0.00 csys = 4.67 CPU) seconds
best regards, Rata
(a bit surprised about the performance-differences)(btw.: ActiveState perl 5.8.8)
Update
As Ikegami pointed out correctly (thanks!!), the line with @arr2 is wrong.
Changing it to
map { push @arr2, ($_+ 2) } @data;
results in
Time taken by map block (with push) was 3 wallclock secs ( 2.33 usr 0.00 sys + 0.00 cusr 0.00 csys = 2.33 CPU) seconds
being similar fast as the foreach ...
In reply to Re^4: Map Vs Foreach
by Ratazong
in thread Map Vs Foreach
by perlCrazy
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |