構造函數php
void __construct ([ mixed $args [, $... ]] )函數
PHP 5 允行開發者在一個類中定義一個方法做爲構造函數。具備構造函數的類會在每次建立新對象時先調用此方法,因此很是適合在使用對象以前作一些初始化工做。this
Note: 若是子類中定義了構造函數則不會隱式調用其父類的構造函數。要執行父類的構造函數,須要在子類的構造函數中調用 parent::__construct()。若是子類沒有定義構造函數則會如同一個普通的類方法同樣從父類繼承(假如沒有被定義爲 private 的話)。spa
Example#1使用新標準的構造函數code
output:
In BaseClass constructor
In BaseClass constructor
In SubClass constructor
In BaseClass constructor對象
爲了實現向後兼容性,若是 PHP 5 在類中找不到 __construct() 函數而且也沒有從父類繼承一個的話,它就會嘗試尋找舊式的構造函數,也就是和類同名的函數。所以惟一會產生兼容性問題的狀況是:類中已有一個名爲 __construct() 的方法卻被用於其它用途時。繼承
與其它方法不一樣,當 __construct() 被與父類 __construct() 具備不一樣參數的方法覆蓋時,PHP 不會產生一個 E_STRICT 錯誤信息。開發
自 PHP 5.3.3 起,在命名空間中,與類名同名的方法再也不做爲構造函數。這一改變不影響不在命名空間中的類。it
Example#2 Constructors in namespaced classesio
析構函數
void __destruct(void)
PHP 5 引入了析構函數的概念,這相似於其它面向對象的語言,如 C++。析構函數會在到某個對象的全部引用都被刪除或者當對象被顯式銷燬時執行。
Example#3析構函數示例
function __destruct() {
print "Destroying " . $this->name . "\n";
}
}
$obj = new MyDestructableClass();
?>
和構造函數同樣,父類的析構函數不會被引擎暗中調用。要執行父類的析構函數,必須在子類的析構函數體中顯式調用 parent::__destruct()。此外也和構造函數同樣,子類若是本身沒有定義析構函數則會繼承父類的。
析構函數即便在使用 exit() 終止腳本運行時也會被調用。在析構函數中調用 exit() 將會停止其他關閉操做的運行。