Maison  >  Article  >  développement back-end  >  Qu’est-ce que le mécanisme de récupération de place PHP ? Explication détaillée du mécanisme de récupération de place PHP

Qu’est-ce que le mécanisme de récupération de place PHP ? Explication détaillée du mécanisme de récupération de place PHP

云罗郡主
云罗郡主original
2019-01-21 14:49:533879parcourir

Le mécanisme de récupération de place de PHP peut être simplement résumé comme un mécanisme COW de comptage de références et de copie sur écriture.

Cet article partage principalement avec vous les connaissances sur la maîtrise du mécanisme de garbage collection PHP, dans l'espoir d'aider tout le monde. [Tutoriel recommandé : Tutoriel php]

Connaissances de base du comptage de références

La réponse du site officiel est la suivante. Chaque variable php a une variable zval dans une variable. conteneur appelé "zval" En plus du type et de la valeur de la variable, le conteneur comprend également deux octets d'informations supplémentaires is_ref et refcount est une valeur booléenne utilisée pour identifier si cette variable appartient à un ensemble de référence. Grâce à cet octet, le moteur PHP peut distinguer les variables ordinaires des variables de référence. Refcount est utilisé pour représenter le nombre de variables pointant vers ce conteneur de variables zval en PHP5, la mémoire de zval est séparée du tas (heap). ). alloués (à quelques exceptions près), PHP a besoin de savoir quels zvals sont utilisés et lesquels doivent être libérés. Cela nécessite donc l'utilisation du comptage de références : la valeur de refcount__gc dans zval est utilisée pour enregistrer le nombre de fois que zval lui-même est référencé. Par exemple, dans l'instruction b = 12, 12 est référencé par deux variables, donc son nombre de références est. 2. Si le compteur de référence devient 0, cela signifie que la variable n'est plus utilisée et que la mémoire peut être libérée.

est le suivant :

<?php
//php zval变量容器
$a = 1;
$b = 1;
$c = &$a;
$d = $b;
$e = range(0, 3);
xdebug_debug_zval(&#39;a&#39;);
xdebug_debug_zval(&#39;b&#39;);
xdebug_debug_zval(&#39;c&#39;);
xdebug_debug_zval(&#39;d&#39;);
xdebug_debug_zval(&#39;e&#39;); >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

Les résultats sont les suivants

a : (refcount=2, is_ref=1), int 1b : (refcount=2, is_ref=0), int 1c : (refcount=2, is_ref=1), int 1d : (refcount=2, is_ref=0), int 1e : (refcount=1, is_ref=0), tableau (taille=4) 0 => ( refcount=1, is_ref=0), int 0 1 => (refcount=1, is_ref=0), int 1 2 => > (refcount= 1, is_ref=0), int 3

<?php
//php zval变量容器
$a = 1;
$b = 1;
$c = &$a;
$d = $b;
$e = range(0, 3);
xdebug_debug_zval(&#39;a&#39;);
xdebug_debug_zval(&#39;b&#39;);
xdebug_debug_zval(&#39;c&#39;);
xdebug_debug_zval(&#39;d&#39;);
xdebug_debug_zval(&#39;e&#39;); >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

Le résultat est le suivant a : (refcount=2, is_ref=1) int 1b : (refcount=0, is_ref=0 ) int 1c : (refcount=2 , is_ref=1) int 1d : (refcount=0, is_ref=0) int 1e : (refcount=1, is_ref=0) tableau (taille=4) 0 => 0, is_ref=0) int 0 1 => (refcount=0, is_ref=0) int 1 2 => (refcount=0, is_ref=0) int 2 3 => ) int 3

Les variables ordinaires ne se souviennent plus de leurs propres nombres. Les types complexes tels que les tableaux se souviennent de leurs propres nombres. Ce n'est que sous le critère 3 que le GC collectera le zval, puis utilisera un nouvel algorithme. pour déterminer si le zval est une poubelle. Alors, comment juger si une telle variable est de véritables déchets ? En termes simples, il s'agit d'effectuer une opération refcount moins 1 pour chaque élément de ce zval. Une fois l'opération terminée, si le refcount de zval=0, alors ce zval est une poubelle. Si le refcount d'un zval augmente, alors ceci. zval est toujours utilisé. , pas une poubelle. Si le refcount d'un zval est réduit à 0, alors le zval peut être libéré. ​​Si le refcount d'un zval est réduit à plus de 0, alors le zval ne peut pas être libéré et le zval est toujours utilisé. zval peut devenir une poubelle.

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