轉自http://ribeter267.blog.163.com/
"
在PHP4的時候出現了建構函式,繼而在PHP5內又添增了析構。這使得PHP更富有物件導向的魅力了。在PHP4時,建構函式用的是與類同名的函數來進行構造這個動作。例如:
<?php/** myClass.php*/class myClass { function myClass { print "This is myClass\n"; }}//建立一個新的執行個體$obj = new myClass();?>
將以上代碼儲存為myClass.php,運行後,會列印出 This is myClass字樣。這是php4的建構函式(當然,為了相容,php5也可以這樣寫)。
在php5裡,有了專門的構造和解構函式。__construct()和__destruct() 。再重新改寫這個myClass.php。<?php/** myClass.php*/class myClass { function __construct() { print "constructor\n"; } function __destruct() { print "destroying\n"; }}//建立一個新的執行個體$obj = new myClass();?>
儲存以後發現列印出了”constructor destroying”。說明構造和析構的確發生了。
目前為止,沒有任何問題。在php5的手冊裡,對於使用__construct還有段說明。如下:
為了實現向後相容性(指PHP 4),如果 PHP 5 在類中找不到 __construct() 函數,它就會嘗試尋找舊式的建構函式,也就是和類同名的函數。因此唯一會產生相容性問題的情況是:類中已有一個名為 __construct() 的方法,但它卻又不是建構函式。
再來看一種情況,當一個衍生類別繼承了基類並且這兩個類都存在構造和解構函式的時候會出現什麼眼的狀況呢?
PHP 5對此的處理手段是: 隱藏基類的構造和析構!
測試代碼:<?php/** myClass.php*/ class baseClass { function __construct() { print "baseClass:\n constructor "; } function __destruct() { print "baseClass:\n destroying "; }} class subClass extends baseClass { function __construct() { print "subClass:\n constructor "; } function __destruct() { print "subClass:\n destroying "; }} $obj = new subClass();?>
儲存運行後,結果列印:subClass: constructor subClass: destroying
可以看到,基類的構造與析構並沒有發生。
這不得不讓人費解,為什麼php5會採取這種的機制呢?
C++的構造與析構的過程是:基類構造->衍生類別構造->衍生類別析構->基類析構。這才是成熟的機制。為什麼PHP 5 會標新立異?
很顯然,這種做法並不十分的明智。
繼續翻看PHP手冊,結果找到了這樣的一種說法:
PHP 4 不會從衍生類別的建構函式中自動調用基類的建構函式。恰當地逐次調用上一級的建構函式是使用者的責任。 (PHP 4)
如果子類中定義了建構函式則不會暗中調用其父類的建構函式。要執行父類的建構函式,需要在子類的建構函式中調用 parent::__construct()。 (PHP 5)
"