When does the difference between a string and a number matter in Perl 5?

后端 未结 4 1738
逝去的感伤
逝去的感伤 2020-12-17 19:30

If a string in Perl 5 passes looks_like_number, it might as well be a number. For instance,

my $s = \"10\" + 5;

results in $s

相关标签:
4条回答
  • 2020-12-17 20:13

    I can only think of one: when checking for truth. Strings that are equivalent to 0, but that are not "0", such as "0.0", "0 but true", "0e0", etc. all pass looks_like_number and evaluate to 0 in numeric context, but are still considered true values.

    0 讨论(0)
  • 2020-12-17 20:18

    An equivalent number and string behave differently in hash keys -- or, more generally, any time we stringify a largish number:

    my (%g, %h);
    $g{ 1234000000000000 } = undef;  # '1.234e+015'       => undef
    $h{'1234000000000000'} = undef;  # '1234000000000000' => undef
    

    Note that we are still within the range where Perl can store the number precisely:

    > perl -e 'printf qq{%.f\n}, 1234000000000000 + $_ for +1, 0, -1'
    1234000000000001
    1234000000000000
    1233999999999999
    
    0 讨论(0)
  • 2020-12-17 20:20
      DB<1> sub is_num { my $x = shift; "$x " ~~ $x }
    
      DB<2> print is_num(123)
    1
      DB<3> print is_num('123')
    
      DB<4> 
    
    0 讨论(0)
  • 2020-12-17 20:21

    When dealing with bitwise operators. 123 ^ 456 is 435, but "123" ^ "456" is "\x05\x07\x05". The bitwise operators work numerically if either operand is a number.

    0 讨论(0)
提交回复
热议问题