Utilisation de la fonction flèche PHP 7.4
La fermeture courte, également appelée fonction flèche, est une fonction courte écrite en PHP. Cette fonctionnalité est très utile lors du passage de fermetures à des fonctions, comme l'utilisation des fonctions array_map
ou array_filter
Voici à quoi elles ressemblent :
// Post 对象的集合 $posts = [/* … */]; $ids = array_map(fn($post) => $post->id, $posts); 而以前,你必须这样写: $ids = array_map(function ($post) { return $post->id; }, $posts);
Résumons comment utiliser la fermeture courte. fonctions
Disponible en PHP 7.4
Commencez par le mot-clé fn
ne peut contenir que une expression, c'est-à-dire l'expression de retour
le mot-clé return peut être ignoré
les paramètres et les indices de type de retour peuvent être utilisés pour n'importe quel type
Une limitation de type plus stricte dans l'exemple ci-dessus peut être écrite comme :
$ids = array_map(fn(Post $post): int => $post->id, $posts);
Il y a deux points qui doivent être mentionnés :
permet également l'utilisation de l'opérateur spread
autorise les références, et les deux paramètres peuvent être utilisés comme valeurs de retour
si vous souhaitez renvoyer un résultat par référence, la syntaxe suivante doit être utilisée :
fn&($x) => $x
En bref, les fermetures courtes fonctionnent de la même manière que les fermetures ordinaires, sauf qu'une seule expression est autorisée.
Une seule ligne
Vous devez bien le comprendre : une fermeture courte ne peut avoir qu'une seule expression. Cela signifie qu'il ne peut pas y avoir plusieurs lignes dans le corps de la fermeture.
La raison est la suivante : le but des fermetures courtes est de réduire les licenciements. Bien sûr, fn
est de toute façon plus court que function
. Cependant, le créateur du RFC, Nikita Popov, estime que si vous utilisez des fonctions qui sont des expressions multilignes, vous tirerez encore moins d'avantages de l'utilisation des fermetures.
Après tout, la définition des fermetures multilignes est déjà redondante, donc avoir et ne pas avoir ces 2 mots-clés ( function
et return
) ne fera pas beaucoup de différence.
C'est à vous de décider si vous êtes d'accord avec ce point de vue. Bien que je puisse penser à de nombreux scénarios de fermetures sur une seule ligne dans mes projets, il existe également de nombreux scénarios de fermetures sur plusieurs lignes, et personnellement, je préférerais une syntaxe plus courte pour ces cas.
Il y a cependant de l'espoir : des fermetures courtes multilignes pourraient être ajoutées à l'avenir, mais ce serait également une RFC distincte.
La valeur de la portée extérieure
Une autre caractéristique notable des fermetures courtes et des fermetures ordinaires est que les fermetures courtes peuvent accéder à l'extérieur sans utiliser les données de portée du mot-clé use.
$modifier = 5; array_map(fn($x) => $x * $modifier, $numbers);
Il convient de noter que les variables de la portée externe ne peuvent pas être modifiées. Parce qu'il s'agit d'une transmission par valeur plutôt que d'une transmission par référence. Cela signifie que vous pouvez modifier la variable $modifier
à l'intérieur de la fermeture courte, mais cela n'aura aucun effet sur la variable $modifier
dans la portée externe.
Bien sûr, il y a une exception, et c'est le mot-clé $this
, qui fonctionne exactement comme dans une fermeture normale :
array_map(fn($x) => $x * $this->modifier, $numbers);
Perspectives de développement
Les fermetures multilignes que j'ai déjà évoquées sont encore une possibilité de développement dans le futur. Une autre idée qui me vient à l'esprit est d'autoriser de courtes fermetures dans les classes, telles que les fonctions getters
et setters
class Post { private $title; fn getTitle() => $this->title; }
Dans l'ensemble, les fermetures courtes sont une fonctionnalité très bienvenue, même s'il existe de nombreux domaines. améliorer. Le plus probable est la fermeture multiligne.
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment installer l'extension mongo dans php7.0 : 1. Créez le groupe d'utilisateurs et l'utilisateur mongodb ; 2. Téléchargez le package de code source mongodb et placez le package de code source dans le répertoire "/usr/local/src/" ; Entrez le répertoire « src/ » ; 4. Décompressez le package de code source ; 5. Créez le répertoire de fichiers mongodb ; 6. Copiez les fichiers dans le répertoire « mongodb/ » 7. Créez le fichier de configuration mongodb et modifiez la configuration.

En php5, nous pouvons utiliser la fonction fsockopen() pour détecter le port TCP. Cette fonction peut être utilisée pour ouvrir une connexion réseau et effectuer certaines communications réseau. Mais en php7, la fonction fsockopen() peut rencontrer certains problèmes, comme ne pas pouvoir ouvrir le port, ne pas pouvoir se connecter au serveur, etc. Afin de résoudre ce problème, nous pouvons utiliser la fonction socket_create() et la fonction socket_connect() pour détecter le port TCP.

Pour résoudre le problème du plugin n'affichant pas installé dans PHP 7.0 : Vérifiez la configuration du plugin et activez le plugin. Redémarrez PHP pour appliquer les modifications de configuration. Vérifiez les autorisations du fichier du plugin pour vous assurer qu'elles sont correctes. Installez les dépendances manquantes pour garantir le bon fonctionnement du plugin. Si toutes les autres étapes échouent, reconstruisez PHP. D'autres causes possibles incluent des versions de plugin incompatibles, le chargement d'une mauvaise version ou des problèmes de configuration PHP.

Les solutions courantes pour les environnements de serveur PHP consistent à s'assurer que la version correcte de PHP est installée et que les fichiers pertinents ont été copiés dans le répertoire du module. Désactivez SELinux temporairement ou définitivement. Vérifiez et configurez PHP.ini pour vous assurer que les extensions nécessaires ont été ajoutées et configurées correctement. Démarrez ou redémarrez le service PHP-FPM. Vérifiez les paramètres DNS pour les problèmes de résolution.

Comment installer et déployer php7.0 : 1. Accédez au site officiel de PHP pour télécharger la version d'installation correspondant au système local ; 2. Extrayez le fichier zip téléchargé dans le répertoire spécifié 3. Ouvrez la fenêtre de ligne de commande et accédez à ; le répertoire "E:\php7" Exécutez simplement la commande "php -v".

Comment définir automatiquement les autorisations d'UnixSocket après le redémarrage du système. Chaque fois que le système redémarre, nous devons exécuter la commande suivante pour modifier les autorisations d'UnixSocket: sudo ...

Causes et solutions pour les erreurs Lors de l'utilisation de PECL pour installer des extensions dans un environnement Docker Lorsque nous utilisons un environnement Docker, nous rencontrons souvent des maux de tête ...

Par rapport à PHP7, PHP8 présente certains avantages et améliorations en termes de performances, de nouvelles fonctionnalités et améliorations de la syntaxe, du système de types, de la gestion des erreurs et des extensions. Cependant, le choix de la version à utiliser dépend de vos besoins spécifiques et des circonstances du projet. Introduction détaillée : 1. Amélioration des performances, PHP8 introduit le compilateur Just-in-Time (JIT), qui peut améliorer la vitesse d'exécution du code ; 2. Nouvelles fonctionnalités et améliorations de la syntaxe, PHP8 prend en charge la déclaration des paramètres nommés et des paramètres facultatifs, création de fonctions L'appel est plus flexible ; des classes anonymes, des déclarations de propriétés de type, etc. sont introduites.
