Fonction Fléchée

Les fonctions fléchées ont été introduit en PHP 7.4 en tant que syntaxe plus concise pour les fonctions anonymes.

Les fonctions anonymes comme les fonctions fléchées sontimplémenté en utilisant la classe Closure.

Les fonctions fléchée ont la forme basique fn (argument_list) => expr.

Les fonctions fléchées supportent les même fonctionalités que les fonctions anonymes, à l'exception que l'utilisation des variables de la portée parente est automatique.

Quand une variable utilisé dans l'expression est définie dans la portée parente, elle sera implicitement capturé par valeur. Dans l'exemple suivant, les fonctions $fn1 et $fn2 se comportement de façon identique.

Exemple #1 Les fonctions fléchées capture les variables par valeur automatiquement

<?php

$y 
1;
 
$fn1 fn($x) => $x $y;
// equivalent to using $y by value:
$fn2 = function ($x) use ($y) {
    return 
$x $y;
};

var_export($fn1(3));
?>

L'exemple ci-dessus va afficher :

4

Ceci fonctionne aussi si les fonctions fléchées sont imbriquées :

Exemple #2 Les fonctions fléchées capture les variables par valeur automatiquement, même imbriquée

<?php

$z 
1;
$fn fn($x) => fn($y) => $x $y $z;
// Outputs 51
var_export($fn(5)(10));
?>

Similairement au fonctions anonymes, la syntaxe des fonctions fléchées permet les signature de fonction arbitraire, ceci inclus les types de paramètres et de retoure, valeur par défaut, variable, aussi bien que le passage et retour par référence. Tous les examples suivant sont des des fonctions fléchées valides :

Exemple #3 Exemples de fonctions fléchées

<?php

fn
(array $x) => $x;
static 
fn(): int => $x;
fn($x 42) => $x;
fn(&$x) => $x;
fn&($x) => $x;
fn($x, ...$rest) => $rest;

?>

Les fonctions fléchées lie les variables par valeur. Ceci est à peu près équivalent à éffectuer un use($x) pour chaque variable $x utilisé à l'intérieur de la fonction fléchée. Un liage par valeur signifie qu'il n'est pas possible de modifier une valeur de la portée extérieure. Les fonctions anonymes peuvent être utilisé à la place pour des liaison par référence.

Exemple #4 Valeurs de la portée extérieure ne peuvent pas être modifié par les fonctions fléchées

<?php

$x 
1;
$fn fn() => $x++; // Has no effect
$fn();
var_export($x);  // Outputs 1

?>

Historique

Version Description
7.4.0 Les fonctions fléchées sont désormais disponible.

Notes

Note: Il est possible d'utiliser func_num_args(), func_get_arg(), et func_get_args() depuis l'intérieur d'une fonction fléchée.

add a note add a note

User Contributed Notes 2 notes

up
3
Koushil Mankali
19 days ago
In example 4  (Values from the outer scope cannot be modified by arrow functions)

<?php

$x
= 1;
$fn = fn() => $x++; // Has no effect
$fn();
var_export($x);  // Outputs 1

?>

Here we can use reference variable in fn(&$x) and pass the value from function call $fn($x) so that we will get the output as expected with out using Anonymous functions.

Example:

<?php

$x
= 1;
$fn = fn(&$x) => $x++;
$fn($x);
var_export($x);

?>

Output : 2 (as expected)

But here it will not take values from parent scope automatically but we have to pass them explicitly.
up
1
dexen dot devries at gmail dot com
12 days ago
Beware compact() not being able to access (import) variables from external scope (known in versions: 7.4.0, 7.4.8) (bug: https://bugs.php.net/bug.php?id=78970).

A workaround is available - use the variable directly; this will cause it to be imported into the arrow function's namespace and make it available to the compact() too.

<?php
$aa
= 111;
$accessing_variable_works = fn($bb) => [ $aa, $bb ];
$compact_is_broken = fn($bb) => compact('aa', 'bb');
$compact_can_work_with_workaround = fn($bb) => compact('aa', 'bb') + ['workaround' => $aa];
var_dump($accessing_variable_works(333));
var_dump($compact_is_broken(555));
var_dump($compact_can_work_with_workaround(777));
?>

result:
array(2) {
  [0]=>
  int(111)
  [1]=>
  int(333)
}
PHP Notice:  compact(): Undefined variable: aa in /home/m/vlt/guitar/tlb/s/public_html/index.php on line 9
array(1) {
  ["bb"]=>
  int(555)
}
array(3) {
  ["aa"]=>
  int(111)
  ["bb"]=>
  int(777)
  ["workaround"]=>
  int(111)
}
To Top