parent::__construct()
执行父类的构造函数。
构造函数在 new 类的时候自动执行。
构造继承类时也自动执行,如果定义新的构造类,需写上parent::__construct()
例子
class A {
public $name; //名字
function __construct($name){ //构造函数
$this->name = $name;
}
function test(){
echo $this->name;
}
}
//派生类
class B extends A{
function __construct(){
parent::__construct("测试源"); //调用或者说继承父zhidao类的构造函数:
self::test();
}
}
$b = new B();
__construct()和__initialize()
关于thinkphp中的__construct()和_initialize()的理解
构造函数:
/**
* 架构函数 取得模板对象实例
* @access public
*/
public function __construct() {
Hook::listen('action_begin',$this->config);
//实例化视图类
$this->view = Think::instance('Think\View');
//控制器初始化
if(method_exists($this,'_initialize'))
$this->_initialize();
}
从Controller类中的构造函数中可以知道,该构造函数会判断对象中是否有_initialize方法,如果有,就执行先_initialize方法,因此,如果我们在自己定义的控制器中,会出现三种情况:
1):有重写构造函数:
①在重写的构造中有实现父类的构造函数(parent::construct() ),
如果该控制器中有定义_initialize()方法,那么,我们在调用该控制器中的方法时,会先执行_initialize()方法,然后再执行我们需要的方法,看代码:
<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller {
public function __construct() {
parent::__construct();
self::b();
echo '我是构造<br />';
}
public function _initialize() {
echo '我先来<br />';
// parent::_initialize();
}
public function index(){
self::b();
echo '这是index';
}
public function b() {
echo 'bbbb<br />';
}
}
/*
当执行index方法时,打印结果:
我先来
bbbb
我是构造
bbbb
这是index
*/
②:在重写的构造中没有实现父类的构造函数,执行方法时,定义的_initialize()方法则没有作用(不会在执行方法时,先执行_initialize方法),看代码:
<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller {
public function __construct() {
// parent::__construct();
self::b();
echo '我是构造<br />';
}
public function _initialize() {
echo '我先来<br />';
// parent::_initialize();
}
public function index(){
self::b();
echo '这是index';
}
public function b() {
echo 'bbbb<br />';
}
}
/*
当执行index方法时,打印结果:
bbbb
我是构造
bbbb
这是index
*/
2)没有重写构造函数,也就是说在我们定义的控制器中没有声明构造函数 这种情况,如果在控制器中有定义_initialize()方法,则当我们调用其他方法时,会先调用_initialize()方法,看代码:
<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller {
// public function __construct() {
// // parent::__construct();
// self::b();
// echo '我是构造<br />';
// }
public function _initialize() {
echo '我先来<br />';
// parent::_initialize();
}
public function index(){
self::b();
echo '这是index';
}
public function b() {
echo 'bbbb<br />';
}
}
/*
当执行index方法时,打印结果:
我先来
bbbb
这是index
*/
另外,_initialize()还可以用来继承
<?php
namespace Home\Controller;
use Think\Controller;
class BaseController extends Controller {
public function __construct() {
parent::__construct();
echo '我是父类<br />';
}
public function _initialize() {
echo '我先来<br />';
}
public function a() {
echo 'aaaa<br />';
}
}
<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends BaseController {
public function __construct() {
parent::__construct();
self::b();
echo '我是构造<br />';
}
public function _initialize() {
parent::_initialize();
echo '我是子类先来<br />';
}
public function index(){
self::b();
echo '这是index';
}
public function b() {
echo 'bbbb<br />';
}
}
/*
当执行index方法时,打印结果:
我先来
我是子类先来
我是父类
bbbb
我是构造
bbbb
这是index
*/
那么,同时存在__construct()(该构造函数初始化了父类的构造函数)和_initialize() ,到底先执行哪个呢?
答案是——先执行_initialize()方法,也就是说,在满足条件下,_initialize()函数是在任何方法执行之前,都要执行的,包括构造函数,
当然,如果你在要执行的方法中又调用的另一个或者多个方法,在另外调用那些方法时,_initialize()方法是不会再执行了,它关联的是你首次调用的方法,也就是说,方法里面干什么,它管不着了。