好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > PHP的垃圾回收機制代碼實例講解

PHP的垃圾回收機制代碼實例講解

熱門標簽:常州地圖標注服務商 地圖標注平臺怎么給錢注冊 福州人工外呼系統哪家強 釘釘打卡地圖標注 衡水外呼系統平臺 百度商鋪地圖標注 安裝電銷外呼系統 新河科技智能外呼系統怎么樣 注冊400電話申請

PHP可以自動進行內存管理,清除不需要的對象,主要使用了引用計數

zval結構體中定義了ref_countis_ref , ref_count是引用計數 ,標識此zval被多少個變量引用 , 為0時會被銷毀
is_ref標識是否使用的 取地址符強制引用

為了解決循環引用內存泄露問題 , 使用同步周期回收算法
比如當數組或對象循環的引用自身 , unset掉數組的時候 , 當refcount-1后還大于0的 , 就會被當成疑似垃圾 , 會進行遍歷 ,并且模擬的刪除一次refcount-1如果是0就刪除 ,如果不是0就恢復

頑固垃圾的產生過程

?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'
?>

對于普通的變量來說,這一切很正常,但是在復合類型變量(數組和對象)中,會發生比較有意思的事情:

?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的內部存儲為 , “life” 的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'
)

如果將數組的引用賦值給數組中的一個元素,有意思的事情就會發生:

?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這個zvalref_count是2 , 是一個環形引用
這時對$a進行unset,那么 a 會 從 符 號 表 中 刪 除 , 同 時 ‘ a會從符號表中刪除,同時` a會從符號表中刪除,同時‘a指向的zvalrefcount_gc`減少1.

?php
$a = array('one');
$a[] = $a;
unset($a);
?>

那么問題就產生了, a 已 經 不 在 符 號 表 中 , 用 戶 無 法 再 訪 問 此 變 量 , 但 是 a已經不在符號表中,用戶無法再訪問此變量,但是 a已經不在符號表中,用戶無法再訪問此變量,但是a之前指向的zval的refcount_gc變為1而不是0,因此不能被回收,從而產生內存泄露,新的GC要做的工作就是清理此類垃圾。

為了解決循環引用內存泄露問題 , 使用同步周期回收算法 , 這種ref_count減1后還大于0的會被作為疑似垃圾

比如當數組或對象循環的引用自身 , unset掉數組的時候 , 當refcount-1后還大于0的 , 會進行遍歷 ,并且模擬的刪除一次refcount-1如果是0就刪除 ,如果不是0就恢復。

到此這篇關于PHP的垃圾回收機制代碼實例講解的文章就介紹到這了,更多相關PHP的垃圾回收機制內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • PHP進階學習之垃圾回收機制詳解
  • PHP析構函數destruct與垃圾回收機制的講解
  • 簡單談談PHP的垃圾回收機制
  • 解讀PHP中的垃圾回收機制
  • PHP垃圾回收機制講解

標簽:白城 鶴崗 克拉瑪依 遼陽 唐山 六安 鷹潭 柳州

巨人網絡通訊聲明:本文標題《PHP的垃圾回收機制代碼實例講解》,本文關鍵詞  PHP,的,垃圾,回收,機制,代碼,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP的垃圾回收機制代碼實例講解》相關的同類信息!
  • 本頁收集關于PHP的垃圾回收機制代碼實例講解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 中文幕无线码一二三四区| 久久无码潮喷A片无码高潮四季 | 男人的天堂精品国产一区| 午夜精品国产精品大乳美女| 在遍地都是丧尸的世界里唯独我不被袭击| 啊灬啊灬啊灬快灬深用力新章节 | 一边吃奶一边做爰爽到爆| 扒开她的乳罩吸奶头视频观后感 | 男人添女人下面免费播放| 91尤物视频| 狠狠挺进稚嫩学生小身体漫画| Hairy熟女浓毛Pics大全HD| 国产国语一级毛片武则天| 日本一区免费观看| 荔枝视频电影资源| 美女考逼| 久久国产成人午夜aⅴ影院| 久久精品噜噜噜成人天堂动漫版| 毛片高清一区二区三区| 丁香六月婷婷| 草莓午夜福利视频app| bl道具震动前列腺play| 18hdxxxx日本护士| 国产v综合v亚洲欧第1集| 欧美色色图| 扒开美女?狂揉?真人玩具| 疯狂做爰全过程免费的网站| 无遮挡爆乳喷汁51漫画| 午夜伦情电午夜伦情电影194| 搡的我好爽视频在线观看| 电影x在线观看| 蝌蚪视频国产成人无码免费 | av天堂吧| 午夜在线视频观看| 裸体欧美军警猛男Gay| 女装大佬TS高潮系列视频| 亚洲永久网址在线观看| 亚洲黄色大片| 香蕉性视频| 免费看黄软件不花钱| h呜呜太大了我受不了|