Maîtriser le mécanisme de garbage collection php

小云云
Libérer: 2023-03-22 12:44:02
original
1835 Les gens l'ont consulté


Le mécanisme de garbage collection de PHP peut être simplement résumé comme un mécanisme de comptage de références, de copie sur écriture et COW. Cet article partage principalement avec vous la connaissance du mécanisme de garbage collection PHP, en espérant aider tout le monde.
  • Connaissances de base du comptage de références La réponse du site officiel est la suivante

    • Chaque variable php existe dans un conteneur de variables appelé "zval "

    • Un conteneur de variable zval, en plus de contenir le type et la valeur de la variable, il comprend également deux octets d'informations supplémentaires is_ref et refcount

    • is_ref 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 utilisées pour représenter le nombre de variables pointant vers ce conteneur de variables zval


  • Comptage de références en PHP5

    En PHP5, la mémoire zval est allouée séparément de la situation du tas (à quelques exceptions près), PHP doit savoir quels zvals sont utilisés et lesquels doivent être publié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 le zval lui-même est référencé, comme

    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.

    Comme suit

<?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;);

>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

结果如下

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),
array (size=4)
  0 => (refcount=1, is_ref=0),int 0
  1 => (refcount=1, is_ref=0),int 1
  2 => (refcount=1, is_ref=0),int 2
  3 => (refcount=1, is_ref=0),int 3
Copier après la connexion

Chaque variable enregistre son propre numéro


  • zval en PHP7

    En PHP7, zval a une nouvelle implémentation. Le changement le plus fondamental est que la mémoire requise par zval n'est plus allouée séparément du tas et ne stocke plus son propre nombre de références . Le nombre de références des types de données complexes (tels que les chaînes, les tableaux et les objets) est stocké par lui-même . Cette implémentation présente les avantages suivants :

    • Les types de données simples n'ont pas besoin d'allouer de la mémoire séparément, ni d'être comptés

    • Non Dans le cas de deux comptages, dans l'objet, seul le comptage stocké dans l'objet lui-même est valide

    • Puisque le comptage est désormais stocké par la valeur elle-même, il peut être combiné avec la structure non-zval Partage de données, par exemple entre zval et la clé de table de hachage

    • Le nombre de pointeurs requis pour l'accès indirect est réduit

<?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;);


>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
结果如下

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)array (size=4)
  0 => (refcount=0, is_ref=0)int 0
  1 => (refcount=0, is_ref=0)int 1
  2 => (refcount=0, is_ref=0)int 2
  3 => (refcount=0, is_ref=0)int 3
Copier après la connexion

Variables ordinaires Ne vous souvenez plus de vos propres nombres. Les types complexes tels que les tableaux se souviennent de leurs propres nombres


  • Qu'est-ce que les déchets

    Seulement Selon la ligne directrice 3, GC collectera le zval, puis un nouvel algorithme sera utilisé pour déterminer si le zval est un déchet. Alors, comment juger si une telle variable est de véritables déchets ?

    Pour faire simple, le refcount est réduit de 1 pour chaque élément du zval Une fois l'opération terminée, si le refcount du zval=0, alors le zval est une poubelle

  • .
    • Si le refcount d'un zval augmente, alors le zval est toujours utilisé et n'est pas une poubelle

    • Si le refcount d'un zval diminue à 0, alors le zval peut être libéré, ce n'est pas une poubelle

    • Si le refcount d'un zval est supérieur à 0 après avoir été réduit, alors le zval ne peut pas être libéré et le zval peut devenir une poubelle

    Recommandations associées :

    Explication détaillée du mécanisme de récupération de place de PHP

    Qu'est-ce que le mécanisme de récupération de place PHP

    Qu'est-ce que le mécanisme de récupération de place PHP

Analyse de l'évolution du mécanisme de garbage collection en PHP5

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal