Maison >développement back-end >tutoriel php >Explication détaillée des déclarations de types de fonctions dans différentes versions de PHP

Explication détaillée des déclarations de types de fonctions dans différentes versions de PHP

小云云
小云云original
2018-01-15 10:00:081782parcourir

Cet article vous donne principalement un résumé de l'utilisation des déclarations de types de fonctions dans différentes versions de PHP. C'est très simple et pratique. Les amis dans le besoin peuvent s'y référer. J'espère que cela pourra vous aider.

PHP7 commence à prendre en charge la déclaration de type scalaire, et la saveur du langage fortement typé est relativement 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 des possibilités infinies pour les types de paramètres et de valeurs de retour. 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 se produira lors de l'appel . Par exemple :


function foo(array $arr = null) {
  ...
}

Déclaration de type scalaire et de valeur de retour (PHP 7)

Les fonctions prennent officiellement en charge les types scalaires (int , bool, float, etc.) et déclaration de type de valeur de retour (le type déclaré est 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 le paramètre et les types de valeur de retour sont possibles Lorsqu'il est 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 et prend également en charge) ; 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 en 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 :

  1. Class/Interface

  2. self, qui ne peut être utilisé que sur ses propres méthodes.

  3. tableau

  4. bool

  5. callable

  6. int

  7. float

  8. string

  9. 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.

Recommandations associées :

Comment utiliser les contraintes de type pour limiter les types de fonctions PHP

Introduction aux types de fonctions de fonction JavaScript

Solution Javascript parfaite pour déterminer les compétences en type de fonction_javascript

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