grinder has asked for the wisdom of the Perl Monks concerning the following question:
Last year on the Paris mongers list, someone posted some convincing code showing how much slower (e.g. 25%) using $_ could be, instead of using a lexical. I was going to say as much to a reply to a node I wrote yesterday, but I thought I'd do a benchmark just to be sure.
The results surprise me. To a number of decimal places, there is absolutely no speed difference between these two routines.
#! /usr/bin/perl -w use strict; use Benchmark; my $scratch = '/tmp/foo'; # create a really big file open OUT, ">$scratch" or die "$scratch: $!\n"; print OUT join( "\n", 1..1000000 ), "\n"; close OUT; timethese( shift || 20, { '$_' => sub { my $count = 0; open IN, $scratch or die "$scratch input: $!\n"; while( <IN> ) { chomp; $count += $_; } close IN; }, 'my' => sub { my $count = 0; open IN, $scratch or die "$scratch input: $!\n"; my $rec; while( defined( $rec = <IN> )) { chomp $rec; $count += $rec; } close IN; }, } ); unlink $scratch;
Is there any assumption I'm overlooking? I've looping through a large file, hopefully large enough to avoid OS caching problems. Maybe there's a more pathological example that highlights a speed difference between $_ and a lexical, but I can't find it (and I can't find the original message in my mail archive).
Does anyone know of a case where $_ is slower than a lexical (and no, I'm not talking about local issues). Thanks.
--
|
---|
Replies are listed 'Best First'. | |
---|---|
Re: The speed of $_ versus a lexical
by ariels (Curate) on Jul 19, 2001 at 14:14 UTC | |
by grinder (Bishop) on Jul 19, 2001 at 14:58 UTC | |
Re: The speed of $_ versus a lexical
by petdance (Parson) on Jul 19, 2001 at 17:13 UTC |