我正在尝试比较使用哈希表还是引用哈希表哪个更好,据我所知,哈希表引用只是指向哈希表本身的指针,因此我认为不应该有速度差异。
我进行了基本的基准测试,并发现哈希表引用比直接使用哈希表平均慢20-27%。
这是我使用的基本基准测试代码:
use Benchmark qw(:all);
cmpthese(10_000_000, {
hash => sub { my %hash = (); },
hashref => sub { my $hahref = {}; }
});
cmpthese(10_000_000, {
hash => sub {
my %hash;
$hash{fname}="first name";
$hash{mname}="middle name";
$hash{lname}="last name";
},
hashref => sub {
my $hahref;
$hahref->{fname}="first name";
$hahref->{mname}="middle name";
$hahref->{lname}="last name";
},
hashrefs => sub {
my $hahref;
$$hahref{fname}="first name";
$$hahref{mname}="middle name";
$$hahref{lname}="last name";
},
});
以下是在戴尔笔记本电脑、Windows 8、Core i7、16MB RAM上的基准测试结果:
Rate hashref hash
hashref 5045409/s -- -17%
hash 6045949/s 20% --
Rate hashrefs hashref hash
hashrefs 615764/s -- -2% -21%
hashref 625978/s 2% -- -19%
hash 775134/s 26% 24% --
Output completed (1 min 6 sec consumed)
我的问题是,如果我的基准测试正确而哈希引用非常慢,为什么大多数模块(如DBI)使用哈希引用返回结果?另外,大多数模块接受哈希引用而不是哈希作为参数,并返回哈希引用而不是哈希。