中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

PHP垃圾回收機(jī)制的簡(jiǎn)單講解

本篇內(nèi)容主要講解“PHP垃圾回收機(jī)制的簡(jiǎn)單講解”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“PHP垃圾回收機(jī)制的簡(jiǎn)單講解”吧!

專(zhuān)注于為中小企業(yè)提供網(wǎng)站設(shè)計(jì)、做網(wǎng)站服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)寶塔免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了數(shù)千家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

   

垃圾回收是什么東西?

在使用 C 語(yǔ)言的時(shí)候,我們都要手動(dòng)使用 free 來(lái)釋放內(nèi)存,在 C 之后的大部分編程語(yǔ)言都會(huì)自帶一個(gè)垃圾回收之類(lèi)的處理能力,也就是我們今天要說(shuō)的垃圾回收機(jī)制,也稱(chēng)為 GC 。在有 GC 能力的開(kāi)發(fā)語(yǔ)言中,我們不需要去關(guān)心什么時(shí)候釋放內(nèi)存,甚至我們完全不需要去了解這一塊的內(nèi)容,因?yàn)檫@些語(yǔ)言在底層已經(jīng)幫我們處理好了關(guān)于內(nèi)存釋放的問(wèn)題。

當(dāng)然這方面的內(nèi)容最出名的就是 Java 中的垃圾回收機(jī)制,其實(shí) PHP 也有相應(yīng)的處理機(jī)制,當(dāng)然,很多 PHPer 可能從來(lái)沒(méi)接觸過(guò),今天我們就來(lái)探討一下這方面的內(nèi)容。

 

PHP 的垃圾回收算法

在之前的文章中,我們有介紹過(guò)引用計(jì)數(shù)的概念  。在 PHP5.3 之前,PHP 的垃圾回收機(jī)制非常簡(jiǎn)單,就是把 refcount 為0的全部清理回收掉,在底層也就是 free 掉了。但是這種方式會(huì)帶來(lái)一個(gè)問(wèn)題,也就是我們?cè)谝糜?jì)數(shù)這篇文章中說(shuō)過(guò)的循環(huán)引用,這種引用問(wèn)題通過(guò)普通的判斷 refcount 的方式是無(wú)法回收的。所以在 PHP5.3 之前,循環(huán)引用是會(huì)造成內(nèi)存泄露的。

之所以強(qiáng)調(diào)版本,那是因?yàn)樵?5.3 之后,PHP 改進(jìn)了垃圾回收的算法,使這種循環(huán)引用得到了解決。(當(dāng)然,我們?cè)谌粘i_(kāi)發(fā)中盡量要避免這種循環(huán)引用的問(wèn)題)。具體算法我們引用官方的圖片:

PHP垃圾回收機(jī)制的簡(jiǎn)單講解

在官方文檔中有詳盡的解釋?zhuān)贿^(guò)還是會(huì)看得很懵逼。我們就用簡(jiǎn)單的語(yǔ)言(說(shuō)人話)來(lái)描述這個(gè)過(guò)程。

首先,我們有個(gè)根緩沖區(qū)的概念,就是圖中的 root 。在底層通過(guò)一系列看不懂搞不明白的算法我們能找到每個(gè)變量的一個(gè)可能根。PHP 會(huì)將變量的可能根放入根緩沖區(qū)。

當(dāng)根緩沖區(qū)滿了的時(shí)候,一般這個(gè)默認(rèn)值是10000,需要修改源碼重新編譯才能修改這個(gè)值。PHP 就會(huì)啟動(dòng)垃圾回收機(jī)制,從根緩沖區(qū)中按照深度遍歷的算法來(lái)查找所有的和這個(gè)可能根相關(guān)的變量,并將某一個(gè)可能根找到的變量的 refcount 減1,做一個(gè)標(biāo)記當(dāng)前這個(gè)“已減”。

然后再次深度遍歷,如果 refcount 不是0的,就加1,如果是0的就保持不變。

接著清除根緩沖區(qū)中的所有可能根,清除而不是刪除。然后清理釋放所有的 refcount 為0的變量?jī)?nèi)容。

是不是已經(jīng)懵逼了?其實(shí)我也很懵逼,都不知道這段是怎么寫(xiě)下來(lái)的....

記住幾個(gè)要點(diǎn)就可以對(duì)付面試并秒殺大部分人了。

  • PHP5.3 后并不是直接看每個(gè)變量的 refcount 是否為0了
  • 使用的算法是深度遍歷,有個(gè)根緩沖區(qū),根據(jù)它來(lái)清理,具體算法需要比較扎實(shí)的 C 和算法基礎(chǔ),學(xué)源碼的時(shí)候再好好研究吧
  • 5.3 之后用算法解決了循環(huán)引用的問(wèn)題
  • 內(nèi)存泄露值會(huì)保持在某一個(gè)范圍,不會(huì)出現(xiàn)立即大范圍崩潰的情況
 

垃圾回收對(duì)性能的影響

前文說(shuō)過(guò),垃圾回收在根緩沖區(qū)滿了之后會(huì)馬上執(zhí)行。其中也會(huì)進(jìn)行兩次的深度遍歷,這就不可避免的帶來(lái)了性能的消耗。畢竟算法的執(zhí)行都是需要耗時(shí)的。不過(guò)相對(duì)于內(nèi)存溢出這種毀滅性的錯(cuò)誤來(lái)說(shuō),垃圾回收帶來(lái)的性能損耗基本上是可以忽略不計(jì)的。

 

到此,相信大家對(duì)“PHP垃圾回收機(jī)制的簡(jiǎn)單講解”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢(xún),關(guān)注我們,繼續(xù)學(xué)習(xí)!

標(biāo)題名稱(chēng):PHP垃圾回收機(jī)制的簡(jiǎn)單講解
網(wǎng)站路徑:http://www.rwnh.cn/article16/ippggg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導(dǎo)航響應(yīng)式網(wǎng)站、服務(wù)器托管、網(wǎng)站策劃、靜態(tài)網(wǎng)站、微信公眾號(hào)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作
湘西| 新闻| 罗平县| 齐河县| 英超| 安阳县| 广东省| 富裕县| 洪江市| 江川县| 茂名市| 华宁县| 江北区| 涿州市| 安康市| 南部县| 洪雅县| 都昌县| 金坛市| 泾源县| 许昌县| 涿州市| 敖汉旗| 花莲县| 信丰县| 凤凰县| 伊金霍洛旗| 朝阳区| 阿拉善盟| 临清市| 双桥区| 德清县| 永宁县| 北海市| 卢湾区| 麟游县| 固安县| 赤壁市| 绥芬河市| 赤峰市| 东莞市|