Thank You for making empty() to support arbitrary expressions!
Le support des générateurs a été ajouté via le mot clé yield. Les générateurs permettent d'implémenter simplement des itérateurs sans le coût ou la complexité de l'implémentation d'une classe implémentant l'interface Iterator.
Un exemple simple qui ré-implémente la fonction range() sous la forme d'un générateur (ou tout du moins, pour les valeurs positives de step) :
<?php
function xrange($start, $limit, $step = 1) {
for ($i = $start; $i <= $limit; $i += $step) {
yield $i;
}
}
echo 'Chiffres impairs simplement : ';
/*
* Notez qu'aucun tableau n'est créé ni retourné,
* ce qui préserve la mémoire.
*/
foreach (xrange(1, 9, 2) as $number) {
echo "$number ";
}
echo "\n";
?>
L'exemple ci-dessus va afficher :
Chiffres impairs simplement : 1 3 5 7 9
Les blocs try-catch supportent désormais un bloc finally pour le code qui devrait être exécuté indépendamment de la levée ou non d'une exception.
Une nouvelle API de hachage des mots de passe existe dorénavant, rendant plus simple la sécurisation des haches et la gestion des mots de passe, en utilisant la même bibliothèque sous-jacente que la fonction crypt(). Voir la documentation sur la fonction password_hash() pour plus de détails.
La structure de contrôle foreach supporte désormais le découpage de tableaux imbriqués vers des variables distinctes via la structure list(). Par exemple :
<?php
$array = [
[1, 2],
[3, 4],
];
foreach ($array as list($a, $b)) {
echo "A: $a; B: $b\n";
}
?>
L'exemple ci-dessus va afficher :
A: 1; B: 2 A: 3; B: 4
La documentation complète est disponible sur la page du manuel consacrée à foreach.
Passer une expression arbitraire au lieu d'une variable à empty() est maintenant supporté. Par exemple :
<?php
function always_false() {
return false;
}
if (empty(always_false())) {
echo "Ceci sera affiché.\n";
}
if (empty(true)) {
echo "Ceci ne sera pas affiché.\n";
}
?>
L'exemple ci-dessus va afficher :
Ceci sera affiché.
Les valeurs litérales des array et string peuvent maintenant être déréférencées directement pour accéder aux éléments et caractères individuels :
<?php
echo "Déréférencement d'un tableau : ";
echo [1, 2, 3][0];
echo "\n";
echo "Déréférencement d'une chaîne de caractères : ";
echo 'PHP'[0];
echo "\n";
?>
L'exemple ci-dessus va afficher :
Déréférencement d'un tableau : 1 Déréférencement d'une chaîne de caractères : P
Il est possible d'utiliser ClassName::class pour récupérer un nom de classe qualifié complet ClassName. Par exemple :
<?php
namespace Name\Space;
class ClassName {}
echo ClassName::class;
echo "\n";
?>
L'exemple ci-dessus va afficher :
Name\Space\ClassName
Le cache opcode Zend Optimiser+ a été ajouté à PHP comme nouvelle extension OPcache. OPcache améliore les performances de PHP en stockant le bytecode précompilé du script en mémoire partagée, faisant ainsi qu'il n'est plus nécessaire pour PHP de charger et d'analyser les scripts à chaque requête. Voir les instructions d'installation pour plus de détails sur l'activation et l'utilisation d'OPcache.
La structure foreach supporte maintenant des clés de tout type. Malgré le fait que les clés non-scalaires ne peuvent survenir dans des tableaux PHP natifs, il est possible pour la méthode Iterator::key() de retourner une valeur de n'importe quel type, et ceci est maintenant correctement géré.
Le gestionnaire SAPI Apache 2.4 est maintenant supporté sous Windows.
Diverses améliorations ont été réalisées dans l'extension GD, incluant :
Thank You for making empty() to support arbitrary expressions!
The array and string dereferencing is awesome! Thanks for this.
Finally, array and string literal dereferencing is here, bless you all!
All the new features are incredible. I had always been waiting for such things to be happened.
Yield is awesome... it's starts to look like a real language now ;-)
class myList {
public $list;
public function __construct($list) {
$this->list = $list;
}
public function select(...$keys) {
$keys_array = array_fill_keys($keys, null);
$items = $this->list;
foreach($items as $item) {
yield array_merge($keys_array, array_intersect_key($item, $keys_array));
}
}
}
After PHP 5.5, foreach with reference in arbitrary array does not generate an error:
foreach ([1, 2, 3, 4] as $key => &$value) {
$value = $value . ' R$';
}
before 5.4, will generate "Cannot create references to elements of a temporary array expression"
Array dereferencing with defaults for possibly empty sources;
<?php
// string(4) "def2"
$x = ([] ?: ["def1", "def2"])[1];
?>