這篇文章給大家介紹怎么在PHP中實現一個垃圾回收機制,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
奇臺網站制作公司哪家好,找創(chuàng)新互聯公司!從網頁設計、網站建設、微信開發(fā)、APP開發(fā)、成都響應式網站建設等網站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯公司公司2013年成立到現在10年的時間,我們擁有了豐富的建站經驗和運維經驗,來保證我們的工作的順利進行。專注于網站建設就選創(chuàng)新互聯公司。頑固垃圾的產生過程
<?php $a = "new string"; ?>
代碼中,$a
變量內部存儲信息為
a: (refcount_gc=1, is_ref_gc=0)='new string'
當把 a 賦 值 給 另 外 一 個 變 量 的 時 候 , a賦值給另外一個變量的時候, a賦值給另外一個變量的時候,a對應的zval的refcount_gc
會加1
<?php $a = "new string"; $b = $a; ?>
此時 a 和 a和 a和b變量對應的內部存儲信息為, a 和 a和 a和b同時指向一個字符串"new string" ,它的refcount變成2
a,b: (refcount_gc=2, is_ref=0)='new string'
當用unset刪除$b變量時,“new string” 的refcount_gc會減1變成1。
<?php $a = "new string"; //a: (refcount_gc=1, is_ref_gc=0)='new string' $b = $a; //a,b: (refcount_gc=2, is_ref=0)='new string' unset($b); //a: (refcount_gc=1, is_ref=0)='new string' ?>
對于普通的變量來說,這一切很正常,但是在復合類型變量(數組和對象)中,會發(fā)生比較有意思的事情:
<?php $a = array('meaning' => 'life', 'number' => 42); ?>
$a
內部存儲信息為:
a: (refcount=1, is_ref=0)=array ( 'meaning' => (refcount=1, is_ref=0)='life', 'number' => (refcount=1, is_ref=0)=42 )
數組變量本身($a)在引擎內部實際上是一個哈希表,這張表中有兩個zval項 meaning和number,所以實際上那一行代碼中一共生成了3個zval,這3個zval都遵循變量的引用和計數原則,用圖來表示:
下面在$a
中添加一個元素,并將現有的一個元素的值賦給新的元素:
<?php $a = array('meaning' => 'life', 'number' => 42); $a['name'] = $a['meaning']; ?>
那么$a
的內部存儲為 , “l(fā)ife” 的ref_count變成2 , 42的ref_count是1:
a: (refcount=1, is_ref=0)=array ( 'meaning' => (refcount=2, is_ref=0)='life', 'number' => (refcount=1, is_ref=0)=42, 'name' => (refcount=2, is_ref=0)='life' )
如果將數組的引用賦值給數組中的一個元素,有意思的事情就會發(fā)生:
<?php $a = array('one'); $a[] = &$a; ?>
這樣 a 數 組 就 有 兩 個 元 素 , 一 個 索 引 為 0 , 值 為 字 符 o n e , 另 外 一 個 索 引 為 1 , 為 a數組就有兩個元素,一個索引為0,值為字符one,另外一個索引為1,為 a數組就有兩個元素,一個索引為0,值為字符one,另外一個索引為1,為a自身的引用,內部存儲如下:
a: (refcount=2, is_ref=1)=array ( 0 => (refcount=1, is_ref=0)='one', 1 => (refcount=2, is_ref=1)=… )
array
這個zval
的ref_count
是2 , 是一個環(huán)形引用
這時對$a
進行unset
,那么 a 會 從 符 號 表 中 刪 除 , 同 時 ‘ a會從符號表中刪除,同時` a會從符號表中刪除,同時‘a指向的
zval的
refcount_gc`減少1.
<?php $a = array('one'); $a[] = &$a; unset($a); ?>
那么問題就產生了, a 已 經 不 在 符 號 表 中 , 用 戶 無 法 再 訪 問 此 變 量 , 但 是 a已經不在符號表中,用戶無法再訪問此變量,但是 a已經不在符號表中,用戶無法再訪問此變量,但是a之前指向的zval的refcount_gc
變?yōu)?而不是0,因此不能被回收,從而產生內存泄露,新的GC
要做的工作就是清理此類垃圾。
為了解決循環(huán)引用內存泄露問題 , 使用同步周期回收算法 , 這種ref_count
減1后還大于0的會被作為疑似垃圾
比如當數組或對象循環(huán)的引用自身 ,unset
掉數組的時候 , 當refcount-1
后還大于0的 , 會進行遍歷 ,并且模擬的刪除一次refcount-1
如果是0就刪除 ,如果不是0就恢復。
關于怎么在PHP中實現一個垃圾回收機制就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
文章題目:怎么在PHP中實現一個垃圾回收機制-創(chuàng)新互聯
分享URL:http://jinyejixie.com/article26/dedhjg.html
成都網站建設公司_創(chuàng)新互聯,為您提供ChatGPT、網站改版、電子商務、網站策劃、網站設計、外貿網站建設
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯