根据问题。我知道有“0 but true”,它在 bool 上下文中为真,否则为假,但可以在 bool 上下文中返回假但具有非零值(明显的地方是返回状态,其中 0 是成功和任何否则是错误)。

最佳答案

否。(除了对双变量和重载对象的乐趣)

Perl 标量的真实性主要取决于字符串值。如果不存在字符串值,则将使用数字字段。

假值是: undef""0 ,并通过首先测试字符串化来避免问题: "0"

并非所有数字为零的评估结果都为假: "0E0" 为真,更自我记录的 "0 but true" 也是如此。后者是特殊情况,以避免出现非数字警告。

但是,输入 dualvars 。标量的数字和字符串字段不必同步。一个常见的对偶变量是 $! 变量,它是数字上下文中的 errno,但是一个包含原因作为字符串的错误字符串。因此,可以创建具有数值 42 和字符串值 "" 的对偶变量,其计算结果为 false。

use Scalar::Util qw/dualvar/;

my $x = dualvar 42, "";
say $x;   # empty string
say 0+$x; # force numeric: 42
say $x ? 1 : 0; # 0

然后 重载对象 。以下类的实例将很好地字符串化,但在 bool 上下文中仍然评估为 false:
package FalseString;
sub new {
  my ($class, $str) = @_;
  bless \$str => $class;
}
use overload
  '""'   => sub { ${shift()} },
  'bool' => sub { 0 };

测试:
my $s = FalseString->new("foo");
say $s;
say $s ? "true" : "false";

打印
foo
false

关于perl - 有 "0 but true",但是 perl 中有 "42 but false"吗?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/16078156/

10-12 17:31