perl哈希hash的常见⽤法介绍
#初始化%h为空数组 %h={};
#⽤数组初始化%h为a=>1,b=>2 %h=('a',1,'b',2);
#意义同上,只是另⼀种更形象化的写法。%h=('a'=>1,'b'=>2);
#如果key是字符串,可以省略引号。下⾯这⾏和上⾯那⾏是⼀样的%h=(a=>1,b=>2);
#⽤{}来访问print “$h{a}\n”;
#打印 $h{b}='2b'; print “$h{b}\n”; #打印2b
#删除key⽤delete delete$h{b}; #从$h删除'b'
undef %h;
得到hash的所有键值
#得到所有keys,顺序取决于hash函数,或者说是乱序@all_keys=keys%h; #所有键值,是按hash的值从⼤往⼩排列的。值的⽐较是数字⽐较(⽐如说,10>9) , @all_keys=sort{$h{$b} => $h{$a}}(keys%h);
exists($h{$key});
想要知道⼀个hash存放多少数据
$hash_size=keys%h #把%h的长度放到$hash_size中print scalar keys %h,"\n"; #打印%h的长度。这⾥⽤了scalar来返回数组长度。
while(my($k,$v)=each%h){print"$k--->$v\n";}
Reference类似于C/C++的指针
$h_ref=\%h; #获得⼀个hash的reference, %aHash=%{$h_ref}; #把hash reference当成hash⽤ $value=$h_ref->{akey}; #这个和%h{akey}是⼀样的
⼀般都是传递⼀个reference到函数
%h=(); $h{a}=1; foo(\%h); print $h{b},"\n"; #打印出2。这个值来⾃于函数foo(), sub foo{my ($h)=@_; print $h->{a},"\n"; #打印出1 $h->{b}=2;}
函数可以返回Perl Hash
正则匹配哈希值
sub foo{my %fh; $fh{a}=1; return %h;} my %h=foo(); print "$h{a}\n"; #打印出1
但是这样等于把整个hash从%fh复制到了%h,效率⽐较低。可以考虑返回hash的引⽤:
sub foo{my %fh; $fh{a}=1; return \%fh;} my $hr=foo(); print "$hr->{a}\n"; #打印出1. my %h=%{foo()} #如果就是想复制,也可以⽤这种⽅法。不⽤担⼼在sub foo⾥的%fh是局部变量,Perl会⾃动管理内存。它会发现%fh被$hr引⽤,就不会清理%fh的内存,并且$hr失效后释放内存。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论