Maison >développement back-end >tutoriel php >Explication détaillée des nouvelles fonctionnalités de type scalaire, opérateur et valeur de retour dans php7
1. opérateur ?? (opérateur de coalescence NULL)
$a = $_GET['a'] ?? 1;
C'est équivalent à :
$a = empty($_GET['a']) ? 1 : $_GET['a'];
On sait que ternaire l'opérateur peut être utilisé comme ceci :
$a ?: 1
Mais ceci est basé sur le principe que $a a été défini. Le nouvel opérateur ?? peut simplifier le jugement. Le code est simplifié et plus intuitif à la fois !
Exemple fourni par la documentation officielle (notez que la syntaxe du paramètre de longueur de côté de ...
n'est disponible qu'en PHP 5.6 ou supérieur) :
<?php function arraysSum(array ...$arrays): array { return array_map(function(array $array): int { return array_sum($array); }, $arrays); } print_r(arraysSum([1,2,3], [4,5,6], [7,8,9]));
À partir de cet exemple, vous pouvez voir que désormais les fonctions (y compris les fonctions anonymes) peuvent spécifier le type de valeur de retour.
Cette fonctionnalité peut nous aider à éviter certains problèmes causés par la conversion de type implicite de PHP. Réfléchir aux résultats attendus avant de définir une fonction peut éviter des erreurs inutiles.
Cependant, il y a aussi une fonctionnalité qui mérite attention ici. PHP 7 ajoute une directive declare : strict_types
, qui utilise le mode strict.
Lors de l'utilisation d'une déclaration de type de valeur de retour, si elle n'est pas déclarée en mode strict, et si la valeur de retour n'est pas du type attendu, PHP la convertira quand même. Mais s'il s'agit du mode strict, une erreur Fatale de TypeError
sera déclenchée.
Mode Force :
<?php function foo($a) : int { return $a; } foo(1.0);
Le code ci-dessus peut être exécuté normalement et la fonction foo renvoie int 1 sans aucune erreur.
Mode strict :
<?php declare(strict_types=1); function foo($a) : int { return $a; } foo(1.0);
Après la déclaration, une erreur fatale sera déclenchée.
# PHP Fatal error: Uncaught TypeError: Return value of foo() must be of the type integer, float returned in test.php:6
La déclaration formelle de type de paramètre des fonctions en PHP 7 peut être scalaire. En PHP 5, il ne peut s'agir que d'un nom de classe, d'une interface, array
ou callable
(PHP 5.4, il peut s'agir d'une fonction, y compris des fonctions anonymes. Vous pouvez désormais également utiliser string
, int
, et float
Compris. bool
<?php // Coercive mode function sumOfInts(int ...$ints) { return array_sum($ints); } var_dump(sumOfInts(2, '3', 4.1));Il est à noter que le problème du mode strict mentionné ci-dessus s'applique également ici : dans le mode obligatoire (par défaut, qui est une conversion de type forcée), les paramètres qui ne correspondent pas au type attendu seront quand même forcés pour taper conversion. , une erreur fatale de
sera déclenchée en mode strict. TypeError
<?php use some\namespace\{ClassA, ClassB, ClassC as C}; use function some\namespace\{fn_a, fn_b, fn_c}; use const some\namespace\{ConstA, ConstB, ConstC};Mais vous devez quand même écrire The nom de chaque classe ou fonction ou const (il n'y a pas de méthode
comme python). from some import *
auto-loading enregistrée par composer recherche l'emplacement en fonction de l'espace de noms de la classe lorsque cette façon d'écrire n'a aucun effet sur celle-ci. .
Parlons-en brièvement : 1. PHP 5.3 a commencé à avoir des fonctions anonymes, et maintenant il existe des classes anonymes 2. arrays ; 3. Closure (Closure) ajoute une méthode d'appel 4. Les générateurs (ou les itérateurs de manière plus appropriée) peuvent avoir une valeur de retour finale (return), ou accéder à un autre générateur (générateur) délégué) via la nouvelle syntaxe de. Les deux nouveautés des générateurs yield from
) peuvent être combinées. Vous pouvez le tester vous-même pour plus de détails. yield from
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!