以下是【金聰采編】分享的內(nèi)容全文:
php的垃圾回收機(jī)制可以簡(jiǎn)單總結(jié)為 引用計(jì)數(shù) 寫(xiě)時(shí)復(fù)制 COW機(jī)制,
本文主要和大家分享掌握php垃圾回收機(jī)制的知識(shí),希望能幫助到大家。
引用計(jì)數(shù)基本知識(shí)
官網(wǎng)的解答如下 每個(gè)php變量存在一個(gè)叫”zval”的變量容器中一個(gè)zval變量容器,除了包含變量的類(lèi)型和值 ,還包括兩個(gè)字節(jié)的額外信息 is_ref 和 refcount is_ref 是個(gè)bool值,用來(lái)標(biāo)識(shí)這個(gè)變量是否是屬于引用集合(reference set)。通過(guò)這個(gè)字節(jié),php引擎才能把普通變量和引用變量區(qū)分開(kāi)來(lái) refcount 用以表示指向這個(gè)zval變量容器的變量個(gè)數(shù) PHP5 中的引用計(jì)數(shù)在PHP5中,zval 的內(nèi)存是單獨(dú)從堆(heap)中分配的(有少數(shù)例外情況),PHP 需要知道哪些 zval 是正在使用的,哪些是需要釋放的。所以這就需要用到引用計(jì)數(shù):zval 中 refcount__gc 的值用于保存 zval 本身被引用的次數(shù),比如 b = 12語(yǔ)句中,12 被兩個(gè)變量引用,所以它的引用計(jì)數(shù)就是 2。如果引用計(jì)數(shù)變成 0,就意味著這個(gè)變量已經(jīng)沒(méi)有用了,內(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每一個(gè)變量都記了自己的數(shù)PHP7 中的 zval在 PHP7 中 zval 有了新的實(shí)現(xiàn)方式。最基礎(chǔ)的變化就是 zval 需要的內(nèi)存不再是單獨(dú)從堆上分配,不再自己存儲(chǔ)引用計(jì)數(shù)。復(fù)雜數(shù)據(jù)類(lèi)型(比如字符串、數(shù)組和對(duì)象)的引用計(jì)數(shù)由其自身來(lái)存儲(chǔ)。這種實(shí)現(xiàn)方式有以下好處:簡(jiǎn)單數(shù)據(jù)類(lèi)型不需要單獨(dú)分配內(nèi)存,也不需要計(jì)數(shù)不會(huì)再有兩次計(jì)數(shù)的情況,在對(duì)象中,只有對(duì)象自身存儲(chǔ)的計(jì)數(shù)是有效的由于現(xiàn)在計(jì)數(shù)由數(shù)值自身存儲(chǔ),所以也就可以和非 zval 結(jié)構(gòu)的數(shù)據(jù)共享,比如 zval 和 hashtable key 之間間接訪問(wèn)需要的指針數(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普通變量不再記自己的數(shù),數(shù)組這樣的復(fù)雜類(lèi)型記自己的數(shù)什么是垃圾只有在準(zhǔn)則3下,GC才會(huì)把zval收集起來(lái),然后通過(guò)新的算法來(lái)判斷此zval是否為垃圾。那么如何判斷這么一個(gè)變量是否為真正的垃圾呢?簡(jiǎn)單的說(shuō),就是對(duì)此zval中的每個(gè)元素進(jìn)行一次refcount減1操作,操作完成之后,如果zval的refcount=0,那么這個(gè)zval就是一個(gè)垃圾如果一個(gè)zval的refcount增加,那么此zval還在使用,不屬于垃圾如果一個(gè)zval的refcount減少到0, 那么zval可以被釋放掉,不屬于垃圾如果一個(gè)zval的refcount減少之后大于0,那么此zval還不能被釋放,此zval可能成為一個(gè)垃圾
以上所述是小編給大家介紹的PHP垃圾回收機(jī)制詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)金聰精品網(wǎng)站的支持!
1.軟件源碼推廣展示:目的展示軟件相關(guān)功能,接收技術(shù)學(xué)習(xí)者測(cè)試、測(cè)評(píng);
2.教程課程信息展示:展示課程信息,傳授課程各階段內(nèi)容;
3.設(shè)計(jì)素材圖片展示:展示素材設(shè)計(jì)理念、思維方式、傳播設(shè)計(jì)理念;
4.福利優(yōu)惠信息展示:分享各類(lèi)最新的福利信息,各種優(yōu)惠信息展示;
以上分享目的僅供學(xué)習(xí)、參考使用,請(qǐng)勿用于其他用途,如果想商業(yè)使用或者代理,請(qǐng)自行聯(lián)系版權(quán)方獲取授權(quán)。任何未獲取授權(quán)的商業(yè)使用與本站無(wú)關(guān),請(qǐng)自行承擔(dān)相應(yīng)責(zé)任。
本站不存儲(chǔ)任何資源文件,敬請(qǐng)周知!
如果您認(rèn)為本頁(yè)信息內(nèi)容侵犯了您的相關(guān)權(quán)益(包含但不限于:著作權(quán)、首發(fā)權(quán)、隱私權(quán)等權(quán)利),或者您認(rèn)為自己是此信息的權(quán)利人但是此信息不是自己發(fā)布的,可以直接版權(quán)舉報(bào)投訴,我們會(huì)根據(jù)網(wǎng)站注冊(cè)協(xié)議、資源分享協(xié)議等協(xié)議處理,以保護(hù)您的合法權(quán)益。
本網(wǎng)站采用 BY-NC-SA 協(xié)議進(jìn)行授權(quán) 轉(zhuǎn)載請(qǐng)注明原文鏈接:掌握PHP垃圾回收機(jī)制詳解

侵權(quán)舉報(bào)/版權(quán)申訴



