perl中的defined和exists

From: http://hi.baidu.com/wangj998/blog/item/3a8d63e9b5b7c035b90e2d3b.html

 

exists

 

 

[root@localhost~]# cat 1.pl
#!/usr/bin/perl -w
use strict;
my $a;
my $b="";
my $c=1;
print "a ok/n" if ( defined $a );
print "b ok/n" if ( defined $b );
print "c ok/n" if ( defined $c );

my %hash=(
        'aa' => 'bejing',
        );

if ( exists $hash{'aa'} )
{
        print "aa exists/n";
}
else
{
        print "aa not exists/n";
}

结果:

[root@localhostr ~]# perl -w 1.pl
b ok
c ok
aa exists
# a 没有赋值过值,所以是undef ,b赋值为空,空也是赋值,c赋值,哈希存在aa值

 

 

defined是用来测试一个变量是否是undef的,也就是说这个变量一定有,只是不知道对这个变量赋过值没有

exists一般是用来测试hash表中是否存在一个变量的

exists判断散列或者数组中某值是否存在,defined判断一个值是不是undef。
存在的也有可能是undef。

defined 一般用来判断变量是非赋值或文件是否都结尾,exists 判断数组哈希是否存在某个变量

 

 

其他网络参考

defined

  • defined EXPR

  • defined

    Returns a Boolean value telling whether EXPR has a value other than the undefined value undef . If EXPR is not present,$_ will be checked.

    Many operations return undef to indicate failure,end of file,system error,uninitialized variable,and other exceptional conditions. This function allows you to distinguish undef from other values. (A simple Boolean test will not distinguish among undef ,zero,the empty string,and "0" ,which are all equally false.) Note that since undef is a valid scalar,its presence doesn't necessarily indicate an exceptional condition: pop returns undef when its argument is an empty array,or when the element to return happens to be undef .

    You may also use defined(&func) to check whether subroutine &func has ever been defined. The return value is unaffected by any forward declarations of &func . Note that a subroutine which is not defined may still be callable: its package may have an AUTOLOAD method that makes it spring into existence the first time that it is called -- see perlsub .

    Use of defined on aggregates (hashes and arrays) is deprecated. It used to report whether memory for that aggregate has ever been allocated. This behavior may disappear in future versions of Perl. You should instead use a simple test for size:

    1. if (@an_array) { print "has array elements/n" }
    2. if (%a_hash) { print "has hash members/n" }

    When used on a hash element,it tells you whether the value is defined,not whether the key exists in the hash. Use "exists" for the latter purpose.

    Examples:

    1. print if defined $switch{'D'};
    2. print "$val/n" while defined ($val = pop (@ary));
    3. die "Can't readlink $sym: $!"
    4. unless defined ($value = readlink $sym);
    5. sub foo { defined &$bar ? &$bar(@_) : die "No bar"; }
    6. $debugging = 0 unless defined $debugging;

    Note: Many folks tend to overuse defined ,and then are surprised to discover that the number 0 and "" (the zero-length string) are,in fact,defined values. For example,if you say

    1. "ab" =~ /a(.*)b/;

    The pattern match succeeds,and $1 is defined,despite the fact that it matched "nothing". It didn't really fail to match anything. Rather,it matched something that happened to be zero characters long. This is all very above-board and honest. When a function returns an undefined value,it's an admission that it couldn't give you an honest answer. So you should use defined only when you're questioning the integrity of what you're trying to do. At other times,a simple comparison to 0 or "" is what you want.

    See also "undef" , "exists" , "ref" .

exists

  • exists EXPR

    Given an expression_r_r_r that specifies a hash element or array element,returns true if the specified element in the hash or array has ever been initialized,even if the corresponding value is undefined.

    1. print "Exists/n" if exists $hash{$key};
    2. print "Defined/n" if defined $hash{$key};
    3. print "True/n" if $hash{$key};
    4. print "Exists/n" if exists $array[$index];
    5. print "Defined/n" if defined $array[$index];
    6. print "True/n" if $array[$index];

    A hash or array element can be true only if it's defined,and defined if it exists,but the reverse doesn't necessarily hold true.

    Given an expression_r_r_r that specifies the name of a subroutine,returns true if the specified subroutine has ever been declared,even if it is undefined. Mentioning a subroutine name for exists or defined does not count as declaring it. Note that a subroutine which does not exist may still be callable: its package may have an AUTOLOAD method that makes it spring into existence the first time that it is called -- see perlsub .

    1. print "Exists/n" if exists &subroutine;
    2. print "Defined/n" if defined &subroutine;

    Note that the EXPR can be arbitrarily complicated as long as the final operation is a hash or array key lookup or subroutine name:

    1. if ( exists $ref->{A}->{B}->{$key}) { }
    2. if ( exists $hash{A}{B}{$key}) { }
    3. if ( exists $ref->{A}->{B}->[$ix]) { }
    4. if ( exists $hash{A}{B}[$ix]) { }
    5. if ( exists &{$ref->{A}{B}{$key}}) { }

    Although the deepest nested array or hash will not spring into existence just because its existence was tested,any intervening ones will. Thus $ref->{"A"} and $ref->{"A"}->{"B"} will spring into existence due to the existence test for the $key element above. This happens anywhere the arrow operator is used,including even:

    1. undef $ref;
    2. if ( exists $ref->{"Some key"}) { }
    3. print $ref; # prints HASH(0x80d3d5c)

    This surprising autovivification in what does not at first--or even second--glance appear to be an lvalue context may be fixed in a future release.

    Use of a subroutine call,rather than a subroutine name,as an argument to exists() is an error.

    1. exists ⊂ # OK
    2. exists &sub(); # Error

相关文章

1. 如何去重 #!/usr/bin/perl use strict; my %hash; while(...
最近写了一个perl脚本,实现的功能是将表格中其中两列的数据...
表的数据字典格式如下:如果手动写MySQL建表语句,确认麻烦,...
巡检类工作经常会出具日报,最近在原有日报的基础上又新增了...
在实际生产环境中,常常需要从后台日志中截取报文,报文的形...
最近写的一个perl程序,通过关键词匹配统计其出现的频率,让...