首頁  >  文章  >  php教程  >  建構函數和析構函數

建構函數和析構函數

黄舟
黄舟原創
2016-12-14 11:10:121164瀏覽

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

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

  繼續是類別的一個強大功能. 一個類別(子類別/衍生類別)可以繼續另一類別(父類別/基底類別)的功能. 衍生類別將包含有基類別的所有屬性和方法,並可以在派生類別中加上其他屬性和方法. 你也可以覆寫基底類別的方法和屬性. 就像3.1.2中顯示的,你可以用extends要害字來繼續一個類別.
  你可能想知道構造函數是如何被繼續的. 當它們和其它方法一起被繼續時,他們不會在創建對象時被執行.
假如你需要這個功能,你需要用第二章提到的::運算子. 它答應你指向一塊命名空間. parent指向父類命名空間,你可以用parent::__construct來調用父類的構造函數.

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

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

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

  析構函數,相反於構造函數. PHP調用它們來將一個對象從內存中銷毀. 默認地,PHP僅僅釋放對象屬性所佔用的內存並銷毀對象相關的資源. 析構函數答應你在使用一個物件之後執行任意程式碼來清除記憶體.

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

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

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


class Counter
{
private static $count = 0;

function __construct()
{
self::$count ;
} -;

}


function getCount()
{
return self::$count;

}

}

//建立第一個實例
$c = new Counter();
//建立第一個實例

$c = new Counter();


/ ($c->getCount() . "
n");

//建立第二個實例
$c2 = new Counter();

//輸出2
print($c->getCount( ) . "
n");

//銷毀實例
$c2 = NULL;

//輸出1
print($c->getCount() . "
n");

?>

  當你新建了一個實例,內存會被預備來存儲所有屬性. 每個實例有自己獨有的一組屬性. 但方法是由該類的所有實例共享的。

更多相關內容親關注PHP中文網(www.php.cn)!

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