PHP基礎之類和對象5——構造函數和析構函數
void__construct?([?mixed$args?[,?$...?]] )
PHP 5 允行開發者在一個類中定義一個方法作為構造函數。具有構造函數的類會在每次創建新對象時先調用此方法,所以非常適合在使用對象之前做一些初始化工作。
Note: 如果子類中定義了構造函數則不會隱式調用其父類的構造函數。要執行父類的構造函數,需要在子類的構造函數中調用parent::__construct()。如果子類沒有定義構造函數則會如同一個普通的類方法一樣從父類繼承(假如沒有被定義為 private 的話)。
Example #1 使用新標準的構造函數
class BaseClass
{
function __construct(){
print 'In BaseClass constructor<br>';
}
}
class SubClass extends BaseClass
{
function __construct(){
parent::__construct();
print 'In SubClass constructor<br>';
}
}
class OtherSubClass extends BaseClass
{}
$obj = new BaseClass();
$obj = new SubClass();
$obj = new OtherSubClass();
輸出結果:
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 起,在命名空間中,與類名同名的方法不再作為構造函數。這一改變不影響不在命名空間中的類。
Example #2 Constructors in namespaced classes
namespace Foo;
class Bar{
public function Bar(){
//在PHP5.3.0-5.3.2中被看作是構造函數
//自PHP5.3.3起被視作一個普通的方法
}
}
析構函數??void__destruct?( void )
PHP 5 引入了析構函數的概念,這類似于其它面向對象的語言,如 C++。析構函數會在到某個對象的所有引用都被刪除或者當對象被顯式銷毀時執行。
Example #3 析構函數示例
<?php
class MyDestructableClass{
function __construct(){
print 'In constructor<br>';
$this->name = 'MyDestructableClass';
}
function __destruct(){
print 'Destroying '.$this->name.’<br>’;
}
}
$obj = new MyDestructableClass();
?>
輸出結果:
In constructor
Destroying MyDestructableClass
和構造函數一樣,父類的析構函數不會被引擎暗中調用。要執行父類的析構函數,必須在子類的析構函數體中顯式調用?parent::__destruct()。此外也和構造函數一樣,子類如果自己沒有定義析構函數則會繼承父類的。
析構函數即使在使用?exit()?終止腳本運行時也會被調用。在析構函數中調用?exit()?將會中止其余關閉操作的運行。
Note:
析構函數在腳本關閉時調用,此時所有的 HTTP 頭信息已經發出。腳本關閉時的工作目錄有可能和在 SAPI(如 apache)中時不同。
Note:
試圖在析構函數(在腳本終止時被調用)中拋出一個異常會導致致命錯誤。
相關文章: