《PHP編程:PHP中構造函數和析構函數解析》要點:
本文介紹了PHP編程:PHP中構造函數和析構函數解析,希望對您有用。如果有疑問,可以聯系我們。
PHP實戰構造函數
PHP實戰void __construct ([ mixed $args [, $... ]] )
PHP實戰PHP 5 允行開發者在一個類中定義一個辦法作為構造函數.具有構造函數的類會在每次創建新對象時先調用此辦法,所以非常適合在使用對象之前做一些初始化工作.
PHP實戰Note: 如果子類中定義了構造函數則不會隱式調用其父類的構造函數.要執行父類的構造函數,需要在子類的構造函數中調用 parent::__construct().如果子類沒有定義構造函數則會如同一個普通的類辦法一樣從父類繼承(假如沒有被定義為 private 的話).
PHP實戰Example#1使用新尺度的構造函數
PHP實戰output:
In BaseClass constructor
In BaseClass constructor
In SubClass constructor
In BaseClass constructor
PHP實戰為了實現向后兼容性,如果 PHP 5 在類中找不到 __construct() 函數并且也沒有從父類繼承一個的話,它就會嘗試尋找舊式的構造函數,也就是和類同名的函數.因此唯一會產生兼容性問題的情況是:類中已有一個名為 __construct() 的辦法卻被用于其它用途時.
PHP實戰與其它辦法不同,當 __construct() 被與父類 __construct() 具有不同參數的辦法覆蓋時,PHP 不會產生一個 E_STRICT 錯誤信息.
PHP實戰自 PHP 5.3.3 起,在命名空間中,與類名同名的辦法不再作為構造函數.這一改變不影響不在命名空間中的類.
PHP實戰Example#2 Constructors in namespaced classes
PHP實戰析構函數
PHP實戰void __destruct(void)
PHP實戰PHP 5 引入了析構函數的概念,這類似于其它面向對象的語言,如 C++.析構函數會在到某個對象的所有引用都被刪除或者當對象被顯式銷毀時執行.
PHP實戰Example#3析構函數示例
PHP實戰?? function __destruct() {
?????? print "Destroying " . $this->name . "\n";
?? }
}
PHP實戰$obj = new MyDestructableClass();
?>
PHP實戰和構造函數一樣,父類的析構函數不會被引擎黑暗調用.要執行父類的析構函數,必須在子類的析構函數體中顯式調用 parent::__destruct().此外也和構造函數一樣,子類如果自己沒有定義析構函數則會繼承父類的.
PHP實戰析構函數即使在使用 exit() 終止腳本運行時也會被調用.在析構函數中調用 exit() 將會中止別的關閉操作的運行.
PHP實戰Note:
析構函數在腳本關閉時調用,此時所有的 HTTP 頭信息已經發出.腳本關閉時的工作目錄有可能和在 SAPI(如 apache)中時分歧.
Note:
試圖在析構函數(在腳本終止時被調用)中拋出一個異常會導致致命錯誤.
歡迎參與《PHP編程:PHP中構造函數和析構函數解析》討論,分享您的想法,維易PHP學院為您提供專業教程。