Как использовать логические переменные в Perl? - PullRequest
210 голосов
/ 24 июня 2009

Я пробовал:

$var = false;
$var = FALSE;
$var = False;

Ни одна из этих работ. Я получаю сообщение об ошибке

Bareword "false" not allowed while "strict subs" is in use.

Ответы [ 8 ]

276 голосов
/ 24 июня 2009

В Perl следующие значения в условных выражениях ложны:

0
'0'
undef
''  # Empty scalar
()  # Empty list
('')

Остальное правда. Нет слов для true или false.

69 голосов
/ 14 апреля 2011

Самое полное и краткое определение ложного, с которым я сталкивался:

Все, что переводится в пустую строку или строку `0`, является ложным. Все остальное правда.

Следовательно, следующие значения являются ложными:

  • Пустая строка
  • Числовое значение ноль
  • неопределенное значение
  • Объект с перегруженным логическим оператором, который оценивает один из вышеперечисленных.
  • Магическая переменная, которая соответствует одному из приведенных выше при получении.

Имейте в виду, что литерал пустого списка оценивается как неопределенное значение в скалярном контексте, поэтому он оценивается как нечто ложное.


Примечание о "истинных нулях"

Хотя числа, которые преобразуются в 0, являются ложными, строки, которые нумеруются до нуля, необязательно. Единственными ложными строками являются 0 и пустая строка. Любая другая строка, даже если она нумеруется, равна true.

Ниже приведены строки, которые имеют значение true как логическое значение, а ноль - число.

  • без предупреждения:
    • "0.0"
    • "0E0"
    • "00"
    • "+0"
    • "-0"
    • " 0"
    • "0\n"
    • ".0"
    • "0."
    • "0 but true"
    • "\t00"
    • "\n0e1"
    • "+0.e-9"
  • С предупреждением:
    • Любая строка, для которой Scalar::Util::looks_like_number возвращает false. (например, "abc")
57 голосов
/ 24 июня 2009

Perl не имеет собственного логического типа, но вы можете использовать сравнение целых чисел или строк, чтобы получить то же поведение. Пример Алана - хороший способ сделать это, используя сравнение целых чисел. Вот пример

my $boolean = 0;
if ( $boolean ) {
    print "$boolean evaluates to true\n";
} else {
    print "$boolean evaluates to false\n";
}

Одна вещь, которую я сделал в некоторых из моих программ, - добавление того же поведения с использованием константы:

#!/usr/bin/perl

use strict;
use warnings;

use constant false => 0;
use constant true  => 1;

my $val1 = true;
my $val2 = false;

print $val1, " && ", $val2;
if ( $val1 && $val2 ) {
    print " evaluates to true.\n";
} else {
    print " evaluates to false.\n";
}

print $val1, " || ", $val2;
if ( $val1 || $val2 ) {
    print " evaluates to true.\n";
} else {
    print " evaluates to false.\n";
}

Строки, помеченные как «константа использования», определяют константу с именем true, которая всегда оценивается как 1, и константу с именем false, которая всегда оценивается как 0. Из-за способа определения констант в Perl следующие строки кода не выполняются а также:

true = 0;
true = false;

В сообщении об ошибке должно быть что-то вроде «Не удается изменить константу в скалярном присваивании».

Я видел это в одном из ваших комментариев о сравнении строк. Вы должны знать, что поскольку Perl комбинирует строки и числовые типы в скалярных переменных, у вас есть другой синтаксис для сравнения строк и чисел:

my $var1 = "5.0";
my $var2 = "5";

print "using operator eq\n";
if ( $var1 eq $var2 ) {
    print "$var1 and $var2 are equal!\n";
} else {
    print "$var1 and $var2 are not equal!\n";
}

print "using operator ==\n";
if ( $var1 == $var2 ) {
    print "$var1 and $var2 are equal!\n";
} else {
    print "$var1 and $var2 are not equal!\n";
}

Разница между этими операторами является очень распространенным источником путаницы в Perl.

16 голосов
/ 03 мая 2010

Я рекомендую use boolean;. Вы должны установить модуль boolean из cpan.

10 голосов
/ 08 октября 2015

Моими любимыми всегда были

use constant FALSE => 1==0;
use constant TRUE => not FALSE;

, который полностью независим от внутреннего представления.

7 голосов
/ 13 апреля 2015

Я наткнулся на учебник , в котором подробно объясняется Какие значения являются истинными и ложными в Perl . Это заявляет, что:

Следующие скалярные значения считаются ложными:

  • undef - неопределенное значение
  • 0 число 0, даже если вы напишите его как 000 или 0.0
  • '' пустая строка.
  • '0' строка, содержащая одну цифру 0.

Все остальные скалярные значения, включая следующие, верны:

  • 1 любой номер, отличный от 0
  • ' ' строка с пробелом в ней
  • '00' два или более 0 символов в строке
  • "0\n" a 0, за которым следует новая строка
  • 'true'
  • 'false' да, даже строка 'false' имеет значение true.

Есть еще один хороший учебник, в котором объясняется Perl true и false .

5 голосов
/ 27 ноября 2013

Красивое объяснение, данное bobf для логических значений: Верно или нет? Краткое справочное руководство

Проверка правды для разных значений

                       Result of the expression when $var is:

Expression          | 1      | '0.0'  | a string | 0     | empty str | undef
--------------------+--------+--------+----------+-------+-----------+-------
if( $var )          | true   | true   | true     | false | false     | false
if( defined $var )  | true   | true   | true     | true  | true      | false
if( $var eq '' )    | false  | false  | false    | false | true      | true
if( $var == 0 )     | false  | true   | true     | true  | true      | true
0 голосов
/ 15 января 2014

используйте следующий префикс файла, это добавит к вашему Perl-скрипту eTRUE и eFALSE, на самом деле это будет REAL (!) True и false (точно так же как java)

#!/usr/bin/perl
use strict;
use warnings;

use constant { #real true false, compatible with encode_json decode_json for later (we don't want field:false... will be field:0...)
                eTRUE  =>  bless( do{\(my $o = 1)}, 'JSON::PP::Boolean' ),
                eFALSE =>  bless( do{\(my $o = 0)}, 'JSON::PP::Boolean' )
             };

На самом деле есть несколько причин, по которым вы должны это использовать.

Моя причина в том, что при работе с JSON у меня есть 0 и 1 в качестве значений для ключей, но этот хак обеспечит сохранение правильных значений в вашем скрипте.

...