PHP析構(gòu)函數(shù)destruct與垃圾回收機(jī)制的講解
析構(gòu)函數(shù)
當(dāng)某個(gè)對(duì)象成為垃圾或者當(dāng)對(duì)象被顯式銷毀時(shí)執(zhí)行。
PHP5中提供的析構(gòu)函數(shù)是__destruct,其與構(gòu)造方法__construct相對(duì)應(yīng)。
垃圾回收——GC(Garbage Collector)
在PHP中,沒有任何變量指向這個(gè)對(duì)象時(shí),這個(gè)對(duì)象就成為垃圾,PHP會(huì)將其在內(nèi)存中銷毀。
這是PHP的GC(Garbage Collector)垃圾處理機(jī)制,垃圾加收可以防止內(nèi)存溢出。
當(dāng)一個(gè)PHP線程結(jié)束時(shí),當(dāng)前占用的所有內(nèi)存空間都會(huì)被銷毀,當(dāng)前程序中的所有對(duì)象同樣被銷毀。
__destruct() 析構(gòu)函數(shù),是在垃圾對(duì)象被回收時(shí)執(zhí)行。
析構(gòu)函數(shù)是由系統(tǒng)自動(dòng)調(diào)用的,也可以被顯式調(diào)用,但不要這樣去做。
如下面程序所示,程序結(jié)束前,所有對(duì)象被銷毀。析構(gòu)函數(shù)被調(diào)用了。
<?php
class Person {
public function __destruct(){
echo '析構(gòu)函數(shù)現(xiàn)在執(zhí)行了 <br />';
echo '這里一般用來設(shè)置、關(guān)閉數(shù)據(jù)庫、關(guān)閉文件等收尾工作';
}
}
$p = new Person();
for($i = 0; $i < 5; $i++){
echo "$i <br />";
}
?>
程序運(yùn)行結(jié)果:
0
1
2
3
4
析構(gòu)函數(shù)現(xiàn)在執(zhí)行了
這里一般用來設(shè)置、關(guān)閉數(shù)據(jù)庫、關(guān)閉文件等收尾工作
當(dāng)對(duì)象沒有指向時(shí),對(duì)象被銷毀。
<?php
class Person {
public function __destruct(){
echo '析構(gòu)函數(shù)現(xiàn)在執(zhí)行了 <br />';
}
}
$p = new Person();
$p = null; // 析構(gòu)函數(shù)在這里執(zhí)行了
$p = "abc"; // 一樣的效果
for($i = 0; $i < 5; $i++){
echo "$i <br />";
}
?>
程序運(yùn)行結(jié)果:
析構(gòu)函數(shù)現(xiàn)在執(zhí)行了
0
1
2
3
4
上面的例子中,我們將$p設(shè)置為空或者賦予$p一個(gè)字符串,這樣$p之前指向的對(duì)象就成為了垃圾對(duì)象。PHP將這個(gè)對(duì)象垃圾銷毀。
php unset變量
<?php
class Person {
public function __destruct(){
echo '析構(gòu)函數(shù)現(xiàn)在執(zhí)行了 <br />';
}
}
$p = new Person();
$p1 = $p;
unset($p);
echo '現(xiàn)在把 $p 被銷毀了,對(duì)象是否也被銷毀了呢? <br />';
for($i = 0; $i < 5; $i++){
echo "$i <br />";
}
echo '現(xiàn)在再把 $p1 也銷毀掉,即已經(jīng)沒有指向?qū)ο蟮淖兞苛?lt;br />';
unset($p1); // 現(xiàn)在沒有指向?qū)ο蟮淖兞苛?析構(gòu)函數(shù)在這里執(zhí)行了
?>
程序運(yùn)行結(jié)果:
現(xiàn)在把 $p 被銷毀了,對(duì)象是否也被銷毀了呢?
0
1
2
3
4
現(xiàn)在再把 $p1 也銷毀掉,即已經(jīng)沒有指向?qū)ο蟮淖兞苛?br /> 析構(gòu)函數(shù)現(xiàn)在執(zhí)行了
unset 銷毀的是指向?qū)ο蟮淖兞?,而不是這個(gè)對(duì)象。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
深思 PHP 數(shù)組遍歷的差異(array_diff 的實(shí)現(xiàn))
還是部門無聊的考題,不過這次考的是 PHP 的能力。題目如下: 給你兩個(gè)分別有 5000 個(gè)元素的數(shù)組,計(jì)算他們的差集 -- 說白了也就是用 PHP 和你認(rèn)為最好的算法實(shí)現(xiàn) array_diff 的算法。初次接到這個(gè)題目,我發(fā)現(xiàn)這非常的簡單,于是按照以往的經(jīng)驗(yàn)“隨便”寫了一個(gè):2008-03-03

