這篇文章主要講解了“PHP垃圾回收機(jī)制的原理”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“PHP垃圾回收機(jī)制的原理”吧!
創(chuàng)新互聯(lián)公司總部坐落于成都市區(qū),致力網(wǎng)站建設(shè)服務(wù)有做網(wǎng)站、成都網(wǎng)站設(shè)計、網(wǎng)絡(luò)營銷策劃、網(wǎng)頁設(shè)計、網(wǎng)站維護(hù)、公眾號搭建、微信小程序定制開發(fā)、軟件開發(fā)等為企業(yè)提供一整套的信息化建設(shè)解決方案。創(chuàng)造真正意義上的網(wǎng)站建設(shè),為互聯(lián)網(wǎng)品牌在互動行銷領(lǐng)域創(chuàng)造價值而不懈努力!
引用計數(shù)基本知識
官網(wǎng)的解答如下 每個php變量存在一個叫”zval”的變量容器中一個zval變量容器,除了包含變量的類型和值 ,還包括兩個字節(jié)的額外信息 is_ref 和 refcount is_ref 是個bool值,用來標(biāo)識這個變量是否是屬于引用集合(reference set)。
通過這個字節(jié),php引擎才能把普通變量和引用變量區(qū)分開來 refcount 用以表示指向這個zval變量容器的變量個數(shù) PHP5 中的引用計數(shù)在PHP5中,zval 的內(nèi)存是單獨(dú)從堆(heap)中分配的(有少數(shù)例外情況),PHP 需要知道哪些 zval 是正在使用的,哪些是需要釋放的。所以這就需要用到引用計數(shù):zval 中 refcount__gc 的值用于保存 zval 本身被引用的次數(shù),比如 b = 12語句中,12 被兩個變量引用,所以它的引用計數(shù)就是 2。如果引用計數(shù)變成 0,就意味著這個變量已經(jīng)沒有用了,內(nèi)存也就可以釋放了。
如下:
<?php //php zval變量容器$a = 1;$b = 1;$c = &$a;$d = $b;$e = range(0, 3); xdebug_debug_zval('a'); xdebug_debug_zval('b'); xdebug_debug_zval('c'); xdebug_debug_zval('d'); xdebug_debug_zval('e'); >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> 結(jié)果如下 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
每一個變量都記了自己的數(shù)PHP7 中的 zval在 PHP7 中 zval 有了新的實現(xiàn)方式。最基礎(chǔ)的變化就是 zval 需要的內(nèi)存不再是單獨(dú)從堆上分配,不再自己存儲引用計數(shù)。復(fù)雜數(shù)據(jù)類型(比如字符串、數(shù)組和對象)的引用計數(shù)由其自身來存儲。
這種實現(xiàn)方式有以下好處:簡單數(shù)據(jù)類型不需要單獨(dú)分配內(nèi)存,也不需要計數(shù)不會再有兩次計數(shù)的情況,在對象中,只有對象自身存儲的計數(shù)是有效的由于現(xiàn)在計數(shù)由數(shù)值自身存儲,所以也就可以和非 zval 結(jié)構(gòu)的數(shù)據(jù)共享,比如 zval 和 hashtable key 之間間接訪問需要的指針數(shù)減少了.
<?php //php zval變量容器$a = 1;$b = 1;$c = &$a;$d = $b;$e = range(0, 3); xdebug_debug_zval('a'); xdebug_debug_zval('b'); xdebug_debug_zval('c'); xdebug_debug_zval('d'); xdebug_debug_zval('e'); >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> 結(jié)果如下 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復(fù)制代碼
普通變量不再記自己的數(shù),數(shù)組這樣的復(fù)雜類型記自己的數(shù)什么是垃圾只有在準(zhǔn)則3下,GC才會把zval收集起來,然后通過新的算法來判斷此zval是否為垃圾。
那么如何判斷這么一個變量是否為真正的垃圾呢?簡單的說,就是對此zval中的每個元素進(jìn)行一次refcount減1操作,操作完成之后,如果zval的refcount=0,那么這個zval就是一個垃圾如果一個zval的refcount增加,那么此zval還在使用,不屬于垃圾如果一個zval的refcount減少到0, 那么zval可以被釋放掉,不屬于垃圾如果一個zval的refcount減少之后大于0,那么此zval還不能被釋放,此zval可能成為一個垃圾.
感謝各位的閱讀,以上就是“PHP垃圾回收機(jī)制的原理”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對PHP垃圾回收機(jī)制的原理這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!
當(dāng)前文章:PHP垃圾回收機(jī)制的原理
分享網(wǎng)址:http://m.rwnh.cn/article2/jdghoc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計、、面包屑導(dǎo)航、軟件開發(fā)、定制開發(fā)、網(wǎng)站內(nèi)鏈
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)