Maison  >  Article  >  développement back-end  >  Faibles références dans PHP 7.4

Faibles références dans PHP 7.4

藏色散人
藏色散人original
2019-11-30 14:28:523393parcourir

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!

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