thinkphp中__construct与_initialize()的区别

熟悉THINKPHP的phper基本上都很熟悉
__initialize()这个方法,我们似乎也很少去使用__construct()

创建的FatherAction.class.php文件



创建的SonAction.class.php文件



运行子类SonAction里的index()可以看到输出的结果:

son

如果将子类改为:



运行结果为;

fatherson

上面的结果可以得出结论:

在执行子类的构造函数时并不会自动调用父类的构造函数,如果你要调用的话,那么要加上parent::__construct()

当我们把上述的构造方法改为THINKPHP
__initialize()方法时运行会发现:结果与前面的一致,若要执行父类的__initialize()方法,也需要使用这一句:   parent::_initialize()

那是不是说明php自带的构造函数__construct()与THINKPHP的_initialize()方法一样的呢?

先贴上两段代码:





当执行子类SonAction的index方法时发现,输出的结果为:father
即子类调用了父类的构造函数,而没有调用子类的_initialize()方法

再贴上两段代码:

hello();
    }
    echo 'father';
  }
}
?>


执行子类SonAction的index方法,发现输入的结果为hellofather

由此可以得出结论:
  1.当THINKPHP的父类有构造函数而子类没有时,THINKPHP不会去执行子类的_initialize();

  2.当THINKPHP的父类子类均有构造函数时,要调用父类的构造函数必须使用parent::__construct()-----------------__initialize()同理;

  3.当THINKPHP的子类同时存在__construct构造函数和_initialize()方法,只会执行子类的__construct构造函数,不会执行__initialize()函数

其实__initialize()函数就相当于一般的调用函数,只有你调用他的时候才会执行。

你可能感兴趣的:(thinkphp中__construct与_initialize()的区别)