一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

深入解析PHP垃圾回收機制對內存泄露的處理

上次說到了refcount和is_ref,這里來說說內存泄露的情況
復制代碼 代碼如下:
$a = array(1, 2, &$a);
unset($a);

在老的php版本中,這里就會出現內存泄露,分析如下:

執行第一行,可以知道$a和$a[2]指向的zval refcount=2,is_ref=1

然后執行第二行,$a將會從符號表中被刪除,同時指向的zval的refcount--,此時refcount=1,因為refcount!=0,故此zval不會被當做垃圾回收,但是此時我們卻失去了$a[2]指向這個zval的入口,因此這個zval成了一塊內存垃圾

同樣的道理可以發生在類內部引用里,例如
復制代碼 代碼如下:
$a = new Man();
$a->self = &$a;
unset($a);

那么如何解決這種問題呢,新的GC機制采用了一個算法來解決這個問題

php有一個root buffer用來存儲zval的節點信息,當root buffer滿了或者手動調用gc函數時,GC算法啟動

對于一個數組或者類類型的zval而言,在垃圾回收機制啟動時,算法會對該zval的數組/類內部的元素/成員的zval進行一次遍歷并將refcount減1,如果說遍歷完成后該zval的refcount被減為0,則說明這個zval是一個內存垃圾,他將被銷毀,見下面的例子
復制代碼 代碼如下:
$a = array(1, 2, &$a, &$a);
unset($a);

容易知道$a指向的zval,假設為z1的refcount=3,is_ref=1

當unset($a)執行的時候,$a就已經從符號表中刪去,同時我們也失去了訪問z1的入口,此時z1 refcount=2,is_ref=1

當GC啟動時,會對該z1的數組元素的zval的refcount進行遍歷減1,遍歷到a[2]時,z1 refcount--, a[3]時 z1 refcount--,此時z1 refcount = 0,即可將z1標記為內存垃圾,算法后將其回收

總結來說可以這么表述:若一個數組類型的zval,對他的元素zval進行一次遍歷,同時將遍歷到的zval的refcount--,如果最后refcount=0的zval,就是垃圾,需要被回收

php技術深入解析PHP垃圾回收機制對內存泄露的處理,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产原创麻豆精品视频 | 免费观看福利视频 | 亚洲国产91在线 | 91年精品国产福利线观看久久 | 中文字幕久久久久 | 成人午夜视频在线播放 | 欧美成人免费午夜影视 | 国产成人亚洲精品无广告 | 亚洲精品天堂自在久久77 | www久久精品| 亚洲国产精品婷婷久久久久 | 亚洲精品国产第1页 | 国产爱搞 | 国产精品亚洲欧美一区麻豆 | 激情综合色综合久久综合 | 欧美亚洲综合一区 | 久久免费公开视频 | 国产精品亚洲一区二区三区在线观看 | 色老板最新网站视频地址 | 色女人在线视频 | 性夜黄a爽爽免费视频国产 性夜影院爽黄e爽痛轻点www | 麻豆一区二区三区四区 | 国产成人香蕉 | 久久精品视频9 | 激情综合婷婷 | 女人笫一次一级毛片 | 我要看三级全黄 | 欧美在线看欧美高清视频免费 | 成人国产欧美精品一区二区 | 亚洲乱码在线观看 | 在线观看黄网站 | 最新69国产成人精品视频69 | 国产精品久久精品福利网站 | 国产人伦激情在线观看 | 亚洲国产成人久久精品动漫 | 国产美女在线精品免费观看 | 美女扒开下面无遮挡免费视频 | 亚洲一区中文 | 五月婷婷欧美 | 日韩在线一区二区三区视频 | 在线色网 |