您好,登錄后才能下訂單哦!
本篇內容主要講解“PHP垃圾回收機制的簡單講解”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“PHP垃圾回收機制的簡單講解”吧!
在使用 C 語言的時候,我們都要手動使用 free 來釋放內存,在 C 之后的大部分編程語言都會自帶一個垃圾回收之類的處理能力,也就是我們今天要說的垃圾回收機制,也稱為 GC 。在有 GC 能力的開發語言中,我們不需要去關心什么時候釋放內存,甚至我們完全不需要去了解這一塊的內容,因為這些語言在底層已經幫我們處理好了關于內存釋放的問題。
當然這方面的內容最出名的就是 Java 中的垃圾回收機制,其實 PHP 也有相應的處理機制,當然,很多 PHPer 可能從來沒接觸過,今天我們就來探討一下這方面的內容。
在之前的文章中,我們有介紹過引用計數的概念 。在 PHP5.3 之前,PHP 的垃圾回收機制非常簡單,就是把 refcount 為0的全部清理回收掉,在底層也就是 free 掉了。但是這種方式會帶來一個問題,也就是我們在引用計數這篇文章中說過的循環引用,這種引用問題通過普通的判斷 refcount 的方式是無法回收的。所以在 PHP5.3 之前,循環引用是會造成內存泄露的。
之所以強調版本,那是因為在 5.3 之后,PHP 改進了垃圾回收的算法,使這種循環引用得到了解決。(當然,我們在日常開發中盡量要避免這種循環引用的問題)。具體算法我們引用官方的圖片:
在官方文檔中有詳盡的解釋,不過還是會看得很懵逼。我們就用簡單的語言(說人話)來描述這個過程。
首先,我們有個根緩沖區的概念,就是圖中的 root 。在底層通過一系列看不懂搞不明白的算法我們能找到每個變量的一個可能根。PHP 會將變量的可能根放入根緩沖區。
當根緩沖區滿了的時候,一般這個默認值是10000,需要修改源碼重新編譯才能修改這個值。PHP 就會啟動垃圾回收機制,從根緩沖區中按照深度遍歷的算法來查找所有的和這個可能根相關的變量,并將某一個可能根找到的變量的 refcount 減1,做一個標記當前這個“已減”。
然后再次深度遍歷,如果 refcount 不是0的,就加1,如果是0的就保持不變。
接著清除根緩沖區中的所有可能根,清除而不是刪除。然后清理釋放所有的 refcount 為0的變量內容。
是不是已經懵逼了?其實我也很懵逼,都不知道這段是怎么寫下來的....
記住幾個要點就可以對付面試并秒殺大部分人了。
前文說過,垃圾回收在根緩沖區滿了之后會馬上執行。其中也會進行兩次的深度遍歷,這就不可避免的帶來了性能的消耗。畢竟算法的執行都是需要耗時的。不過相對于內存溢出這種毀滅性的錯誤來說,垃圾回收帶來的性能損耗基本上是可以忽略不計的。
到此,相信大家對“PHP垃圾回收機制的簡單講解”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。