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

Explication détaillée des nouvelles fonctionnalités de type scalaire, opérateur et valeur de retour dans php7

伊谢尔伦
伊谢尔伦original
2017-06-27 10:19:571450parcourir

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 !

2. Déclaration du type de valeur de retour de la fonction

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

3. Déclaration de type scalaire

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, &#39;3&#39;, 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

4. Utiliser la déclaration par lots

En PHP 7, use peut déclarer plusieurs classes ou fonctions ou const en une seule phrase :

<?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 *

Une question à noter est la suivante : si vous utilisez un framework basé sur Composer et PSR-4, cette méthode d'écriture peut-elle charger avec succès des fichiers de classe ? En fait, c'est possible. La méthode

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

(retour et

) 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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn