它們有些不同,因爲與許多其他語言不同,其中所有複雜類型僅作爲引用提供,Perl具有實際的簡單散列類型和單獨的引用類型,可以作爲任何其他類型的代理。你可以在perlguts找到關於這方面的血腥細節。
最後,這兩個例子都從相同的存儲中提取數據,當然,但第二次調用會稍微長一點,因爲它花費時間盡職地創建對純HV的引用,然後將它解引用,就像您問過的一樣。您可以使用B::Concise
模塊研究發動機罩下的細節。
%hash = ('a'=>1,'b'=>2);
print $hash{'b'};
print (\%hash)->{'b'};
簡明輸出:
$ perl -MO=Concise deref.pl
t <@> leave[1 ref] vKP/REFC ->(end)
1 <0> enter ->2
2 <;> nextstate(main 1 deref.pl:1) v:{ ->3
b <2> aassign[t3] vKS ->c
- <1> ex-list lKP ->8
3 <0> pushmark s ->4
4 <$> const[PV "a"] s ->5
5 <$> const[IV 1] s ->6
6 <$> const[PV "b"] s ->7
7 <$> const[IV 2] s ->8
- <1> ex-list lK ->b
8 <0> pushmark s ->9
a <1> rv2hv[t2] lKRM*/1 ->b
9 <#> gv[*hash] s ->a
c <;> nextstate(main 1 deref.pl:2) v:{ ->d
i <@> print vK ->j
d <0> pushmark s ->e
h <2> helem sK/2 ->i
f <1> rv2hv sKR/1 ->g
e <#> gv[*hash] s ->f
g <$> const[PV "b"] s ->h
j <;> nextstate(main 1 deref.pl:3) v:{ ->k
s <2> helem vK/2 ->t
q <1> rv2hv[t7] sKR/1 ->r
p <@> print sK ->q
k <0> pushmark s ->l
o <1> refgen lK/1 ->p
- <1> ex-list lKRM ->o
l <0> pushmark sRM ->m
n <1> rv2hv[t6] lKRM/1 ->o
m <#> gv[*hash] s ->n
r <$> const[PV "b"] s ->s
deref.pl syntax OK