tp框架中構造函數__construct()與初始化函數_initialize()的區別


<?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(){

}
}

?>

輸出“son”

如果將子類改為:

<?php


class SonAction extends FatherAction{
   public function __construct(){
    parent::__construct();
    echo 'son';
   }
  function index(){

  }
}

?>

輸出“fatherson”.

上面的結果可以得出結論:

在執行子類的構造函數時並不會自動調用父類的構造函數,如果你要調用的話,那么要加上parent::__construct()

當我們把上述的構造方法改為THINKPHP_initialize()方法時運行會發現:結果與前面的一致,若要執行父類的_initialize()方法,也需要使用這一句:

parent::_initialize()那是不是說明php自帶的構造函數__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(){

  }

}

?>輸出的結果為: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();

  當THINKPHP的父類子類均有構造函數時,要調用父類的構造函數必須使用parent::__construct()-----------------_initialize()同理;

  當THINKPHP的子類同時存在__construct構造函數和_initialize()方法,只會執行子類的__construct構造函數(這個上述代碼沒有,可以自己測試)。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM