[導讀] PHP垃圾回收機制是php5之後才有的這個東西,下面我來跟大家介紹一下關於PHP垃圾回收機制一些理解,希望對各位同學有所幫助。 php 5 3之前使用的垃圾回收機制是單純的引用計數,也就是每個記憶體物件都分配一個計數
PHP垃圾回收機制是php5之後才有的這個東西,下面我來跟大家介紹一下關於PHP垃圾回收機制一些理解,希望對各位同學有幫助。
php 5.3之前使用的垃圾回收機制是單純的“引用計數”,也就是每個內存對像都分配一個計數器,當內存對像被變量引用時,計數器1;當變量引用撤掉後,計數器-1 ;當計數器=0時,表示記憶體物件沒有被使用,該記憶體物件則被銷毀,垃圾回收完成。
「引用計數」有問題,就是當兩個或多個物件互相引用形成環狀後,記憶體物件的計數器則不會消減為0;這時候,這一組記憶體物件已經沒用了,但是不能回收,從而導致內存洩露;
php5.3開始,使用了新的垃圾回收機制,在引用計數基礎上,實現了一種複雜的算法,來檢測內存對像中引用環的存在,以避免內存洩露。
該演算法可以參考下面這篇文章,這是這篇小總結的主要參考文獻:) :淺談PHP5中垃圾回收演算法(Garbage Collection)的演化
看下面的例子
Example 1: gc. php
<?php error_reporting(E_ALL); $a = 'I am test.'; $b = & $a; echo $b ."n"; ?>
不用說% php -f gc.php 輸出結果非常明了:
hy0kl% php -f gc.php I am test.
好,下一個:
Example 2:
<?php error_reporting(E_ALL); $a = 'I am test.'; $b = & $a; $b = 'I will change?'; echo $a ."n"; echo $b ."n"; ?> 执行结果依然很明显: hy0kl% php -f gc.php I will change? I will change?
君請看呢?
<?php error_reporting(E_ALL); $a = 'I am test.'; $b = & $a; unset($a); echo $a ."n"; echo $b ."n"; ?>
Example 4:
hy0kl% php -f gc.php Notice: Undefined variable: a in /usr/local/www/apache22/data/test/gc.php on line 8 I am test.
其實如果Example 3 理解了,這個與之異曲同工.
猛的第一感覺是什麼樣的?
<?php error_reporting(E_ALL); $a = 'I am test.'; $b = & $a; unset($b); echo $a ."n"; echo $b ."n"; ?>
沒錯,這就是輸出結果,對PHP GC 已有深入理解的phper 不會覺得有什麼奇怪,說實話,當我第一次運行這段程式碼時很意外,卻讓我對PHP GC 有更深刻的理解了.那麼下面與之同工的例子自然好理解了.
Example 6:
hy0kl% php -f gc.php I am test. Notice: Undefined variable: b in /usr/local/www/apache22/data/test/gc.php on line 9