perl哈希hash的常见用法介绍(hash pipe)万万没想到

随心笔谈2年前发布 admin
260 0 0

文章摘要

这篇文章介绍了 Perl 哈希(Hash)的基本操作方法,包括初始化、访问、删除键、传递哈希到函数以及返回哈希引用等。内容涵盖以下核心知识点: 1. **初始化**:可以通过空数组初始化、数组形式初始化或更直观的写法创建 Perl 哈希。 2. **访问键值**:使用 `print` 和 `delete` 方法访问和删除键值,也可以通过索引访问键值。 3. **哈希长度**:使用 `keys` 方法获取哈希的键数组,并通过 `scalar` 转换获得键的数量。 4. **遍历哈希**:使用 `each` 方法遍历哈希的键值对,并输出结果。 5. **引用传递**:可以通过引用传递哈希到函数,或返回哈希引用(哈希引用对象)。 6. **内存管理**: Perl 会管理和自动内存哈希引用对象,避免内存泄漏问题。 文章内容简洁明了,适合初学者快速了解 Perl 哈希的基本用法和注意事项。



基本用法

#初始化%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’

清空Perl Hash

undef %h;

得到hash的所有键值

#得到所有keys,顺序取决于hash函数,或者说是乱序@all_keys=keys%h;  #所有键值,是按hash的值从大往小排列的。值的比较是数字比较(比如说,10>9) ,  @all_keys=sort{$h{$b}=> $h{$a}}(keys%h);

判断Perl Hash是否包含key

 exists($h{$key});

Perl Hash的长度

想要知道一个hash存放多少数据

$hash_size=keys%h #把%h的长度放到$hash_size中print scalar keys %h,”\n”; #打印%h的长度。这里用了scalar来返回数组长度。

遍历一个Perl Hash

while(my($k,$v)=each%h){print”$k—>$v\n”;}

Reference引用

Reference类似于C/C++的指针

$h_ref=\%h;    #获得一个hash的reference,   %aHash=%{$h_ref};   #把hash reference当成hash用 $value=$h_ref->{akey}; #这个和%h{akey}是一样的

传递Perl Hash到函数

一般都是传递一个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;}

函数返回hash,或者hash引用(hashreference)

函数可以返回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失效后释放内存。

您可能感兴趣的文章:php-perl哈希算法实现(times33哈希算法)Perl 哈希的创建和引用介绍Perl哈希表用法解析perl哈希的一个实例分析Perl 哈希Hash用法之入门教程Perl与JS的对比分析(数组、哈希)

© 版权声明

相关文章