PHP析構函數(shù)destruct與垃圾回收機制的講解
析構函數(shù)
當某個對象成為垃圾或者當對象被顯式銷毀時執(zhí)行。
PHP5中提供的析構函數(shù)是__destruct,其與構造方法__construct相對應。
垃圾回收——GC(Garbage Collector)
在PHP中,沒有任何變量指向這個對象時,這個對象就成為垃圾,PHP會將其在內存中銷毀。
這是PHP的GC(Garbage Collector)垃圾處理機制,垃圾加收可以防止內存溢出。
當一個PHP線程結束時,當前占用的所有內存空間都會被銷毀,當前程序中的所有對象同樣被銷毀。
__destruct() 析構函數(shù),是在垃圾對象被回收時執(zhí)行。
析構函數(shù)是由系統(tǒng)自動調用的,也可以被顯式調用,但不要這樣去做。
如下面程序所示,程序結束前,所有對象被銷毀。析構函數(shù)被調用了。
<?php
class Person {
public function __destruct(){
echo '析構函數(shù)現(xiàn)在執(zhí)行了 <br />';
echo '這里一般用來設置、關閉數(shù)據(jù)庫、關閉文件等收尾工作';
}
}
$p = new Person();
for($i = 0; $i < 5; $i++){
echo "$i <br />";
}
?>
程序運行結果:
0
1
2
3
4
析構函數(shù)現(xiàn)在執(zhí)行了
這里一般用來設置、關閉數(shù)據(jù)庫、關閉文件等收尾工作
當對象沒有指向時,對象被銷毀。
<?php
class Person {
public function __destruct(){
echo '析構函數(shù)現(xiàn)在執(zhí)行了 <br />';
}
}
$p = new Person();
$p = null; // 析構函數(shù)在這里執(zhí)行了
$p = "abc"; // 一樣的效果
for($i = 0; $i < 5; $i++){
echo "$i <br />";
}
?>
程序運行結果:
析構函數(shù)現(xiàn)在執(zhí)行了
0
1
2
3
4
上面的例子中,我們將$p設置為空或者賦予$p一個字符串,這樣$p之前指向的對象就成為了垃圾對象。PHP將這個對象垃圾銷毀。
php unset變量
<?php
class Person {
public function __destruct(){
echo '析構函數(shù)現(xiàn)在執(zhí)行了 <br />';
}
}
$p = new Person();
$p1 = $p;
unset($p);
echo '現(xiàn)在把 $p 被銷毀了,對象是否也被銷毀了呢? <br />';
for($i = 0; $i < 5; $i++){
echo "$i <br />";
}
echo '現(xiàn)在再把 $p1 也銷毀掉,即已經沒有指向對象的變量了<br />';
unset($p1); // 現(xiàn)在沒有指向對象的變量了,析構函數(shù)在這里執(zhí)行了
?>
程序運行結果:
現(xiàn)在把 $p 被銷毀了,對象是否也被銷毀了呢?
0
1
2
3
4
現(xiàn)在再把 $p1 也銷毀掉,即已經沒有指向對象的變量了
析構函數(shù)現(xiàn)在執(zhí)行了
unset 銷毀的是指向對象的變量,而不是這個對象。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
相關文章
PHP實現(xiàn)針對日期,月數(shù),天數(shù),周數(shù),小時,分,秒等的加減運算示例【基于strtotime】
這篇文章主要介紹了PHP實現(xiàn)針對日期,月數(shù),天數(shù),周數(shù),小時,分,秒等的加減運算,結合實例形式分析了基于strtotime的簡單日期時間運算技巧,非常具有實用價值,需要的朋友可以參考下2017-04-04
PHP+jQuery實現(xiàn)雙擊修改table表格功能示例
這篇文章主要介紹了PHP+jQuery實現(xiàn)雙擊修改table表格功能,涉及php數(shù)組讀取、遍歷及jQuery動態(tài)響應修改頁面元素屬性相關操作技巧,需要的朋友可以參考下2019-02-02
php變量與JS變量實現(xiàn)不通過跳轉直接交互的方法
這篇文章主要介紹了php變量與JS變量實現(xiàn)不通過跳轉直接交互的方法,涉及php與javascript變量傳輸及代碼混編相關操作技巧,需要的朋友可以參考下2017-08-08
關于查看MSSQL 數(shù)據(jù)庫 用戶每個表 占用的空間大小
本篇文章是對查看MSSQL數(shù)據(jù)庫用戶每個表占用的空間大小進行了詳細的分析介紹,需要的朋友參考下2013-06-06

