Maison >développement back-end >tutoriel php >Explication détaillée de la déclaration de type des fonctions dans différentes versions de PHP
Cet article vous donne un résumé de la façon d'utiliser les déclarations de type de fonction dans différentes versions de PHP. C'est très simple et pratique. Les amis dans le besoin peuvent s'y référer
PHP7 commence à prendre en charge les déclarations de type scalaire et. langues fortement typées. La saveur est plus forte. J'ai rencontré deux pièges lors de l'utilisation de cette fonctionnalité : une fois lors de la déclaration de booléen, et plus récemment lors de la déclaration de double. Afin d'éviter de commettre des erreurs similaires à l'avenir, j'ai lu une fois la documentation officielle. Cet article est un résumé de l'utilisation des déclarations de type dans les fonctions PHP après l'avoir lu.
Syntaxiquement, la définition des fonctions PHP a traversé plusieurs périodes :
Antiquité (PHP 4)
Il est très simple de définir une fonction, déclaré en utilisant la syntaxe de function name(args) {body}. Les types de paramètres et de valeurs de retour ne peuvent pas être spécifiés, et il existe un nombre illimité de types de paramètres et de valeurs de retour possibles. C’est de loin la manière la plus courante de déclarer une fonction.
Déclaration de la valeur des paramètres de type tableau et référence (PHP 5)
Le tableau, la classe, l'interface et l'appelable peuvent être utilisés dans la déclaration de fonction. À partir de la version 5.6, les constantes (y compris les constantes de classe) sont prises en charge comme paramètres par défaut, ainsi que les tableaux de paramètres (préfixés par des points de suspension...). Par exemple :
function sum(...$numbers) { $sum = 0; foreach ($numbers as $number) { $sum += $number; } return $sum; }
Remarque : Si la valeur du paramètre peut être nulle, null doit être la valeur par défaut du paramètre, sinon une erreur sera se produire lors d’un appel. Par exemple :
function foo(array $arr = null) { ... }
Déclaration du type scalaire et de la valeur de retour (PHP 7)
Les fonctions prennent officiellement en charge le scalaire types (int, bool, float, etc.) et type de valeur de retour (le type peut être déclaré comme étant le même que le paramètre). À partir de cette version, écrire PHP revient à écrire Java.
Malheureusement, si la valeur de retour de la fonction peut être nulle, le type de valeur de retour ne peut pas être spécifié. Par exemple :
function getModel() : Foo { if ($this->_model === null) { $this->_model = xxxx; // get from db or otherelse } return $this->_model; // 如果$this->_model仍是null,运行出错 }
Les paramètres et les valeurs de retour peuvent être nuls ainsi que la déclaration de type de retour void (PHP 7.1)
Lorsque les paramètres et les valeurs de retour Lorsque le type peut être nul, modifiez-le avec un point d'interrogation (?) avant le type, ce qui peut résoudre le problème de la valeur nulle (n'entre pas en conflit avec le paramètre par défaut, la déclaration de type ajoute un itérable) ; prend également en charge la valeur de retour de type void. Par exemple :
function getModel(?int $id) : ?Foo { if ($id !== null) { $this->_model = xxxx; } else { $this->_model = yyyy; } return $this->_model; } // 调用 $foo->getModel(null); $foo->getModel(100); // 函数声明了参数并且没有提供默认参数,调用时不传入参数会引发错误 // 将函数声明改成 getModel(?int $id = 100) {},可以不传参数 $foo->getModel();
Lorsque la valeur de retour de la fonction est vide, aucun type ne peut être suivi d'un retour dans le corps de la fonction, ou aucune instruction de retour n'apparaît.
function test(array $arr) : void { if (!count($arr) { return; } array_walk($arr, function ($elem) {xxxx}); }
Après avoir examiné l'historique ci-dessus, nous pouvons voir que depuis PHP 7.1, la déclaration des types de fonctions est très complète (même si elle n'est pas beaucoup utilisée dans pratique).
Parlons des écueils rencontrés dans la pratique. Les types disponibles pour la déclaration du type de paramètre et de valeur de retour sont :
Class/Interface
self, qui ne peut être utilisé que sur ses propres méthodes.
tableau
bool
callable
int
float
string
iterable
Notez qu'il n'y a pas de types booléens et doubles dans la liste ! À moins que vous ne définissiez ces deux types, il est erroné de les utiliser dans les paramètres et les valeurs de retour !
C'est aussi là que PHP est un peu pénible. Les deux mots-clés double et float en utilisation normale sont presque les mêmes. Par exemple, doubleval est un alias de floatval, is_double est un alias de is_float et (double) et (float) ont le même effet lors de la conversion. Mais cela ne fonctionne pas lorsqu'il s'agit de déclarations de type. La même situation se produit avec bool et boolean.
Résumé
À l'heure actuelle, la version stable de PHP 7.2 a été publiée. Il est recommandé d'utiliser autant que possible PHP 7.1 et les versions ultérieures dans les nouveaux projets. Afin d'écrire du code clair et maintenable, les types déclaratifs sont recommandés. Il est recommandé d'utiliser des valeurs nulles uniquement pour les types de référence ou les chaînes, et d'essayer de ne pas utiliser null pour les paramètres de type scalaire tels que int/float. Essayez de ne pas utiliser func_get_argc et d'autres fonctions sauf si nécessaire.
Explication sur la façon de compter le nombre d'occurrences d'un nombre dans un tableau trié en PHP
PHP appelle ffmpeg pour prendre des captures d'écran vidéo et assembler le script
Explication détaillée des scénarios et des règles de vérification dans Yii2
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!