Références faibles en PHP 7.4
Introduction
Les références faibles permettent aux programmeurs de conserver des références à des objets pendant que cet objet n'empêche pas l'objet d'être détruits ; ils sont utiles pour implémenter des structures de type cache. Ils bénéficient actuellement d'un support étendu en PHP.
Les implémentations actuelles de WeakRef sont toutes implémentées en surchargeant les gestionnaires d'objets, l'implémentation la plus populaire (pecl-weakref) modifie la pile allouée à la mémoire en lecture seule, et PHP 7.3 la rendra indisponible. D'autres implémentations qui modifient les gestionnaires d'objets d'une autre manière courent également le risque de se briser et de s'appuyer sur un comportement indéfini et de gâcher la cohérence.
D'autres implémentations sont possibles, krakjoe/uref est une implémentation qui utilise des fonctionnalités de bas niveau (mprotect, 0xCC, signaux) pour implémenter des références faibles, mais au détriment de la portabilité, générant des erreurs de segmentation, de la mémoire protégée et du Signal implicite limitations du gestionnaire.
En principe, les objets de référence faibles ne sont pas compliqués, il suffit d'(ab)utiliser Zend ou un calque en dessous, puisque nous ne le supportons pas directement.
Recommandation
Nous soutenons directement les références faibles de la manière la plus simple.
API
L'API :
final class WeakReference { public static function create(object $object) : WeakReference; public function get() : ?object; }
Modifications rétrocompatibles
Aucune.
Traduction : https://wiki.php.net/rfc/weakrefs
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!