1.構造函數實例化類的時候會自動調用,
2.子類沒有構造函數,會直接調用父類的構造涵數, 繼承父類的屬性和方法
3.子類和父類都有構造函數,實例子類時不會自動調用父類構造函數,只會調用子類自己的構造函數。
用 parent::__construct();可以調用父類的構造函數。
ThinkPHP中的__initialize()和類的構造函數__construct()
網上有很多關於__initialize()的說法和用法,總感覺不對頭,所以自己測試了一下。將結果和大家分享。不對請更正。
首先,我要說的是
1、__initialize()不是php類中的函數,php類的構造函數只有__construct().
2、類的初始化:子類如果有自己的構造函數(__construct()),則調用自己的進行初始化,如果沒有,則調用父類的構造函數進行自己的初始化。
3、當子類和父類都有__construct()函數的時候,如果要在初始化子類的時候同時調用父類的__constrcut(),則可以在子類中使用parent::__construct().
如果我們寫兩個類,如下
- class Action{
- public function __construct()
- {
- echo 'hello Action';
- }
- }
- class IndexAction extends Action{
- public function __construct()
- {
- echo 'hello IndexAction';
- }
- }
- $test = new IndexAction;
- //output --- hello IndexAction
很明顯初始化子類IndexAction的時候會調用自己的構造器,所以輸出是'hello IndexAction'。
但是將子類修改為
- class IndexAction extends Action{
- public function __initialize()
- {
- echo 'hello IndexAction';
- }
- }
那么輸出的是'hello Action'。因為子類IndexAction沒有自己的構造器。
如果我想在初始化子類的時候,同時調用父類的構造器呢?
- class IndexAction extends Action{
- public function __construct()
- {
- parent::__construct();
- echo 'hello IndexAction';
- }
- }
這樣就可以將兩句話同時輸出。
當然還有一種辦法就是在父類中調用子類的方法。
- class Action{
- public function __construct()
- {
- if(method_exists($this,'hello'))
- {
- $this -> hello();
- }
- echo 'hello Action';
- }
- }
- class IndexAction extends Action{
- public function hello()
- {
- echo 'hello IndexAction';
- }
- }
這樣也可以將兩句話同時輸出。
而,這里子類中的方法hello()就類似於ThinkPHP中__initialize()。
所以,ThinkPHP中的__initialize()的出現只是方便程序員在寫子類的時候避免頻繁的使用parent::__construct(),同時正確的調用框架內父類的構造器,所以,我們在ThnikPHP中初始化子類的時候要用__initialize(),而不用__construct(),當然你也可以通過修改框架將__initialize()函數修改為你喜歡的函數名。
1.然后去繼承的父類里面一看,原來里面寫了一個_initialize()的方法,原來是子類的構造函數覆蓋了父類的,所以報錯了,所以需要繼承一下父類的構造函數:
parent::__construct();
其實_initialize()是TP封裝的方法,和php自帶的__construct()方法是差不多一樣的,不過有一點區別,那就是_initialize() 它會幫我們自己繼承父類的構造函數,而__construct()源生自帶的,需要自己去繼承父類構造函數
轉:http://www.thinkphp.cn/code/367.html
轉 :https://blog.csdn.net/jacko_chan/article/details/54406178