首頁  >  文章  >  後端開發  >  php析構函數的正確理解

php析構函數的正確理解

黄舟
黄舟原創
2017-07-02 10:10:371264瀏覽

如果你在一個類別中聲明一個函數,命名為construct,這個函數將被當成是一個建構函數並在建立一個物件實例時被執行. 清楚地說,是兩個下劃線. 就像其它任何函數一樣,建構函數可能有參數或預設值. 你可以定義一個類別來建立一個物件並將其屬性全放在一個語句(statement)中.

你也可以定義一個名為destruct的函數,PHP將在物件被銷毀前呼叫這個函數. 它稱為PHP析構函數.

#繼承是類別的一個強大功能.一個類別(子類別/衍生類別)可以繼承另一類別(父類別/基底類別)的功能.衍生類別將包含有基底類別的所有屬性和方法,並可以在衍生類別中加上其他屬性和方法. 你也可以覆寫基底類別的方法和屬性. 就像3.1.2中顯示的,你可以用extends關鍵字來繼承一個類別.

你可能想知道建構子是如何被繼承的. 當它們和其它方法一起被繼承時,他們不會在創建對象時被執行.
如果你需要這個函數,你需要用第二章提到的::運算符. 它允許你指向一塊命名空間. parent指向父類別命名空間,你可以用parent::construct來呼叫父類別的建構子.

一些物件導向語言在類別之後命名建構子. PHP的前幾個版本也是如此,到現在這種方法仍然有效.也就是:如果你把一個類別命名為Animal並且在其中建立一個命名也是Animal的方法,則這個方法就是構造函數.如果一個類別的同時擁有construt建構函式和與類別名稱相同的函式,PHP將會把construct看作建構函式.這使得用以前的PHP版本所寫的類別仍然可以使用. 但新的腳本(PHP5)應當使用construct.

PHP的這種新的宣告建構函式的方法可以使建構函式有一個獨一無二的名稱,無論它所在的類別的名稱是什麼. 這樣你在改變類別的名稱時,就不需要改變構造函數的名稱.

你可能在PHP中給構造函數一個像其它類方法一樣的訪問方式. 訪問方式將會影響從一定範圍內實例化對象的能力. 這允許實現一些固定的設計模式,如Singleton模式.

PHP析構函數,相反於建構子. PHP呼叫它們來將一個物件從記憶體中銷毀. 預設地,PHP僅僅釋放對象屬性所佔用的記憶體並銷毀物件相關的資源. 析構函數允許你在使用一個物件之後執行任意程式碼來清除記憶體.

當PHP決定你的腳本不再與物件相關時,PHP析構函數將被呼叫. 在一個函數的命名空間內,這會發生在函數return的時候. 對於全局變數,這發生於腳本結束的時候. 如果你想明確地銷毀一個對象,你可以給指向該對象的變數分配任何其它值. 通常將變數賦值勤為NULL或呼叫unset .

下面的例子中,計算從類別中實例化的物件的個數. Counter類別從建構子開始增值,在PHP析構函數減值.

一旦你定義了一個類別,你可以用new來建立一個這個類別的實例. 類別的定義是設計圖,實例則是放在組裝線上的元件. New需要類別的名稱,並傳回該類別的一個實例. 如果建構函式需要參數,你應當在new後輸入參數.

< ?php   
class Counter { private static $count = 0;   
function construct() { self::$count++; }   
function destruct() { self::$count--; }   
function getCount() { return self::$count; } }   
//建立第一个实例  
$c = new Counter();  
 //输出1   
print($c->getCount() . "<br>\n");   
//建立第二个实例   
$c2 = new Counter();   
//输出2   
print($c->getCount() . "<br>\n");   
//销毁实例   
$c2 = NULL;   
//输出1  
 print($c->getCount() . "<br>\n");   
?>

當你新建了一個PHP析構函式實例,記憶體會被準備來儲存所有屬性. 每個實例有自己獨有的一組屬性. 但方法是由該類別的所有實例共享的.

以上是php析構函數的正確理解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn