Opérateurs logiques, || ou ou?


104

Je me souviens avoir lu il y a quelque temps sur les opérateurs logiques qui, dans le cas de OR, utiliser ||était mieux que or(ou vice versa).

Je devais juste l'utiliser dans mon projet quand il m'est revenu, mais je ne me souviens plus quel opérateur était recommandé ou si c'était même vrai.

Quel est le meilleur et pourquoi?

Réponses:


139

Il n'y a pas de «meilleur» mais le plus courant l'est ||. Ils ont une priorité différente et ||fonctionneraient comme on s'y attendrait normalement.

Voir aussi: Opérateurs logiques ( l'exemple suivant est pris à partir de là ):

// The result of the expression (false || true) is assigned to $e
// Acts like: ($e = (false || true))
$e = false || true;

// The constant false is assigned to $f and then true is ignored
// Acts like: (($f = false) or true)
$f = false or true;

11
et $e = true || $x = 'foo'ne définira pas en $xraison d'un court-circuit, pas en raison d'une priorité plus élevée.
Matt Kieran

1
Il est également intéressant de noter que ceux-ci renvoient toujours une valeur booléenne, contrairement à de nombreux autres langages où ils renvoient la dernière valeur vérifiée. Donc en PHP (27 || 0) renvoie vrai , pas 27 .
TextGeek

@TextGeek, "ceux-ci"? 27 or 0revient 27pour moi.
Jānis Elmeris

@ Jānis Elmeris - vous avez raison, j'aurais dû me référer uniquement au "||" Cas.
TextGeek

2
@TextGeek, en fait, vous avez raison, cela orrenvoie également un booléen. Juste sa priorité est si faible qu'il semble parfois qu'il fasse autre chose. :) print 27 or 0imprimerait 27parce orqu'il arrive après print 27 . BTW, echon'est pas dupe - echo 27 or 0produirait 1.
Jānis Elmeris

43

Ils sont utilisés à des fins différentes et ont en fait des priorités d'opérateurs différentes. Les opérateurs &&et ||sont destinés aux conditions booléennes, tandis que andet orsont destinés au flux de contrôle.

Par exemple, ce qui suit est une condition booléenne:

if ($foo == $bar && $baz != $quxx) {

Cela diffère du flux de contrôle:

doSomething() or die();

die()La fonction sera appelée si doSomething()retournera falseou null? Et si doSomething()revient trueou rien?
giannis christofakis

5
doSomething()est évalué comme un booléen. S'il renvoie une valeur que PHP considère comme véridique ( true, une chaîne non vide, etc.), il n'appellera pas die().
Matthew Ratzloff

23

La différence entre respectivement || et OR et && et AND est la priorité de l'opérateur :

$bool = FALSE || TRUE;

  • interprété comme ($bool = (FALSE || TRUE))
  • la valeur de $boolestTRUE

$bool = FALSE OR TRUE;

  • interprété comme (($bool = FALSE) OR TRUE)
  • la valeur de $boolestFALSE

$bool = TRUE && FALSE;

  • interprété comme ($bool = (TRUE && FALSE))
  • la valeur de $boolestFALSE

$bool = TRUE AND FALSE;

  • interprété comme (($bool = TRUE) AND FALSE)
  • la valeur de $boolestTRUE

5

Source: http://wallstreetdeveloper.com/php-logical-operators/

Voici un exemple de code pour travailler avec des opérateurs logiques:

<html>

<head>
    <title>Logical</title>
</head>

<body>
    <?php
        $a = 10;
        $b = 20;
        if ($a>$b)
        {
            echo " A is Greater";
        }
        elseif ($a<$b)
        {
            echo " A is lesser";
        }
        else
        {
             echo "A and B are equal";
        }
    ?>
    <?php
        $c = 30;
        $d = 40;
        //if (($a<$c) AND ($b<$d))
        if (($a<$c) && ($b<$d))
        {
            echo "A and B are larger";
        }
        if (isset($d))
            $d = 100;
        echo $d;
        unset($d);
    ?>
    <?php
        $var1 = 2;
        switch($var1)
        {
            case 1:  echo "var1 is 1";
                     break;
            case 2:  echo "var1 is 2";
                     break;
            case 3:  echo "var1 is 3";
                     break;
            default: echo "var1 is unknown";
        }
    ?>
</body>
</html>

Le lien est rompu.
Peter Mortensen

2

Je sais que c'est un vieux sujet mais quand même. Je viens de rencontrer le problème dans le code que je débogue au travail et peut-être que quelqu'un peut avoir un problème similaire ...

Disons que le code ressemble à ceci:

$positions = $this->positions() || [];

Vous vous attendez (comme vous en avez l'habitude par exemple avec javascript) que lorsque $ this-> positions () retourne false ou null, $ positions est un tableau vide. Mais ce n'est pas le cas. La valeur est TRUE ou FALSE dépend de ce que renvoie $ this-> positions ().

Si vous avez besoin d'obtenir la valeur de $ this-> positions () ou un tableau vide, vous devez utiliser:

$positions = $this->positions() or [];

ÉDITER:

L'exemple ci - dessus ne fonctionne pas comme prévu , mais la vérité est que , ||et orn'est pas la même chose ... Essayez ceci:

<?php

function returnEmpty()
{
  //return "string";
  //return [1];
  return null;
}

$first = returnEmpty() || [];
$second = returnEmpty() or [];
$third = returnEmpty() ?: [];

var_dump($first);
var_dump($second);
var_dump($third);
echo "\n";

Voici le résultat:

bool(false)
NULL
array(0) {
}

Donc, en fait, la troisième option ?:est la bonne solution lorsque vous souhaitez définir une valeur renvoyée ou un tableau vide.

$positions = $this->positions() ?: [];

Testé avec PHP 7.2.1


c'est une réponse incorrecte, le deuxième exemple fonctionne exactement comme le premier
WayFarer

@WayFarer bien, ce n'est pas correct (il y a un problème) mais vous vous trompez aussi (|| et OR n'est pas le même) - voir ma modification
Zdeněk

droite, opérateurs || et 'ou' ont une priorité différente, donc, votre deuxième exemple fonctionne comme: (($ second = returnEmpty ()) ou []); Donc, la réponse à la question initiale serait || est mieux, utilisez-le toujours, jusqu'à ce que vous compreniez vraiment pourquoi voulez-vous utiliser 'ou'
WayFarer

1
$positions = $this->positions() ?? [];est probablement ce que vous voulez.
évêque

0

Je ne pense pas que l'un soit fondamentalement meilleur qu'un autre, mais je suggérerais de rester avec || car c'est la valeur par défaut dans la plupart des langues.

EDIT: Comme d'autres l'ont souligné, il y a en effet une différence entre les deux.


0

Il n'y a rien de mal ou de mieux, cela dépend juste de la priorité des opérateurs. Puisque ||a une priorité plus élevée que or, ||est donc principalement utilisé.


-3

Certains langages utilisent le court-circuit, et d'autres utilisent une évaluation booléenne complète (si vous le savez, c'est similaire à la directive $Ben Pascal).

Explications:

function A(){
    ...Do something..
    return true;
}

function B(){
    ...Do something..
    return true;
}

if ( A() OR B() ) { .....

Dans cet exemple, la fonction B()ne sera jamais exécutée. Puisque la fonction A()retourne TRUE, le résultat de l'instruction OR est connu de la première partie sans qu'il soit nécessaire d'évaluer la deuxième partie de l'expression.

Cependant avec ( A() || B() ), la seconde partie est toujours évaluée quelle que soit la valeur de la première.

Pour une programmation optimisée, vous devez toujours utiliser ORce qui est le plus rapide (sauf dans le cas où la première partie revient falseet la seconde partie doit en fait être évaluée).


Ce n'est pas «la meilleure réponse !!». Veuillez faire défiler vers le haut et prendre la réponse la plus votée pour une bonne explication. Avec le ||, Bne sera pas appelé. Les deux opérateurs font exactement la même chose, sauf que la priorité est différente.
bzeaman

"vous devriez toujours utiliser OR qui est plus rapide" Hmm, je me demande si c'est vrai ... alors vérifions que: 3v4l.org/5QSAA/vld#tabs 3v4l.org/PdjJP/vld#tabs Le nombre d'opcodes est le même. Cela n'a donc pas d'importance en termes de performances.
Jens A. Koch
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.