|
通常來(lái)說(shuō),如果php對(duì)象存在遞歸引用,就會(huì)出現(xiàn)內(nèi)存泄漏。這個(gè)Bug在php里已經(jīng)存在很久很久了,先讓我們來(lái)重現(xiàn)這個(gè)Bug,示例代碼如下:
<?phpclass Foo { function __construct() { $this->bar = new Bar($this); }}class Bar { function __construct($foo) { $this->foo = $foo; }}for ($i = 0; $i < 100; $i++) { $obj = new Foo(); unset($obj); echo memory_get_usage(), "/n";}?>
運(yùn)行以上代碼,你會(huì)發(fā)現(xiàn),內(nèi)存使用量本應(yīng)該不變才對(duì),可實(shí)際上卻是不斷增加,unset沒(méi)有完全生效。
現(xiàn)在的開(kāi)發(fā)很多都是基于框架進(jìn)行的,應(yīng)用里存在復(fù)雜的對(duì)象關(guān)系,那么就很可能會(huì)遇到這樣的問(wèn)題,下面看看有什么權(quán)宜之計(jì):
<?phpclass Foo { function __construct() { $this->bar = new Bar($this); } function __destruct() { unset($this->bar); }}class Bar { function __construct($foo) { $this->foo = $foo; }}for ($i = 0; $i < 100; $i++) { $obj = new Foo(); $obj->__destruct(); unset($obj); echo memory_get_usage(), "/n";}?>
辦法有些丑陋,不過(guò)總算是對(duì)付過(guò)去了。幸運(yùn)的是這個(gè)Bug在php5.3的CVS代碼中已經(jīng)被修復(fù)了。
對(duì)此,在進(jìn)行php程序設(shè)計(jì)時(shí)有必要加以注意!相信本文所述對(duì)大家的php程序設(shè)計(jì)有一定的參考價(jià)值。
php技術(shù):PHP對(duì)象遞歸引用造成內(nèi)存泄漏分析,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。