這篇文章主要介紹了ThinkPHP中類別的建構子_construct()與_initialize()的區別,文中介紹的非常詳細,相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。
前言
相信熟悉THINKPHP的phper基本上都很熟悉_initialize()
這個方法,我們似乎也很少去使用_construct()
,除非自己寫插件,否則還真是很少用到。
今天查看程式碼突然看到_construct()
這個php自帶的建構方法,我的第一感覺是比較陌生,雖然之前學習java時常遇到,但是很久不用基本忘記。我平常的習慣是將知識的重點寫
在我那本小筆記上,但是很久不寫字,曾經高中那個那種飄逸靈動的書寫筆法徹底丟到異次元。再加上之前的想法,所以就來學習學習技術大牛們寫寫博客,這不是為了裝逼,而只是讓自己工作成果的點點滴滴都能不隨時間流逝而消散。下面來看看詳細的介紹吧。
先貼上程式碼(我的環境是wamp,使用了TP框架):
建立的FatherAction.class. php檔案
<?php class FatherAction extends Action{ public function __construct(){ echo 'father'; } } ?>
所建立的SonAction.class.php檔案
<?php class SonAction extends FatherAction{ public function __construct(){ echo 'son'; } function index(){ } } ?>
運行子類別SonAction裡的index()
可以看到輸出的結果:
son
如果將子類別改為:
<?php class SonAction extends FatherAction{ public function __construct(){ parent::__construct(); echo 'son'; } function index(){ } } ?>
#運行結果為;
##
fatherson
上面的結果可以下結論:
#在執行子類別的建構子時並不會自動呼叫父類的建構函數,如果你要呼叫的話,那麼要加上parent::__construct()
THINKPHP_initialize()方法時運行會發現:結果與前面的一致,若要執行父類別的
_initialize()方法,也需要使用這句話:
parent::_initialize()
__construct()與THINKPHP的
_initialize()方法一樣的呢?
先貼上兩段程式碼:
<?php class FatherAction extends Action{ public function __construct(){ echo 'father'; } } ?>
<?php class SonAction extends FatherAction{ public function _initialize(){ echo 'son'; } function index(){ } } ?>當執行子類別SonAction的index方法時發現,輸出的結果為:father即子類別呼叫了父類別的建構函數,而沒有呼叫子類別的
_initialize()方法
再貼上兩段程式碼:
<?php class FatherAction extends Action{ public function __construct(){ if(method_exists($this,"hello")){ $this->hello(); } echo 'father'; } } ?>
<?php class SonAction extends FatherAction{ public function _initialize(){ echo 'son'; } function index(){ } function hello(){ echo 'hello'; } } ?>執行子類別SonAction的index方法,發現輸入的結果為hellofather
#由此可以得出結論:
當THINKPHP的當父類別有建構子類別沒有時,THINKPHP不會去執行子類別的_initialize() ;
parent::__construct() -----------------
_initialize()同理;
__construct建構子和
_initialize()方法,只會執行子類別的
__construct建構子(這個本人親測,上述代碼沒有)。
以上是ThinkPHP中類別的建構子_construct()與_initialize()的差別的詳細內容。更多資訊請關注PHP中文網其他相關文章!