首頁 >後端開發 >php教程 >第四節 建構子與析構函式 [4]_PHP教程

第四節 建構子與析構函式 [4]_PHP教程

WBOY
WBOY原創
2016-07-21 16:11:04819瀏覽


如果你在一個類別中聲明一個函數,命名為__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 __destruct()
{
self::$count--;
} function getCount()
{
return self::$count;
}
} //建立第一個實例
$c = new Counter(); //輸出1
print($c->getCount() . "
n"); //建立第二個實例
$c2 = new Counter(); //輸出2
print($c->getCount() . "
n"); //銷毀實例
$c2 = NULL; //輸出1
print($c->getCount() . "
n");
?> 當你新建了一個實例,記憶體會被準備來儲存所有屬性. 每個實例有自己獨有的一組屬性. 但方法是由該類別的所有實例共享的。

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/314091.htmlTechArticle如果你在一個類別中宣告一個函式,命名為__construct,這個函式會被當成是建構子並在建立一個物件實例時被執行. 清楚地說,__是兩個下劃...
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn