in reply to Re: Re: grep items not matching an RE
in thread grep items not matching an RE
The EXPR version's also a good bit faster since it doesn't have to do the block enter/leave setup each item.
$ perl -MBenchmark=cmpthese -le 'cmpthese( 500_000, { BLOCK => sub { g +rep { /a/ } qw( aa bb ab cd ef ) }, EXPR => sub { grep /a/, qw( aa bb + ab cd ef ) }, } )' Benchmark: timing 500000 iterations of BLOCK, EXPR ... BLOCK: 16 wallclock secs (16.78 usr + 0.05 sys = 16.83 CPU) @ 29 +712.16/s (n=500000) EXPR: 4 wallclock secs ( 3.90 usr + 0.04 sys = 3.94 CPU) @ 12 +6984.13/s (n=500000) Rate BLOCK EXPR BLOCK 29712/s -- -77% EXPR 126984/s 327% --
|
|---|