$ perl -MBenchmark=cmpthese -le 'cmpthese( 500_000, { BLOCK => sub { grep { /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) @ 29712.16/s (n=500000) EXPR: 4 wallclock secs ( 3.90 usr + 0.04 sys = 3.94 CPU) @ 126984.13/s (n=500000) Rate BLOCK EXPR BLOCK 29712/s -- -77% EXPR 126984/s 327% --