对PHP构造函数的理解
做项目的时候遇到了一些错误,最终分析,是php的构造方法在作怪,这里重新整理了一下:php5开始可以在类中声明__construct构造方法,当对象被实例化的时候,该方法被调用。
注意:
1.如果在继承的子类中没有构造方法而父类中有构造方法,那么当实例化子类时,父类的构造方法会被隐式调用。
2.如果子类有构造方法,父类中也有构造方法,那么子类要显示调用parent::__construct()才能父类的构造方法。
为了向后兼容,如果在php5类中没有找到__construct()方法,它会去找与类名相同的方法名的构造器,但是如果同时使用两个构造器,有可能会发生 E_STRICT 级别的错误信息:
(以下代码是本人web环境:win32+php5.3.8+apache2.2测试)
<?phpclass B{//构造器public function B(){echo 'this is B()';}public function __construct(){echo 'this is __construct()';}public function other(){//do something}}$b = new B();?>
结果:Strict Standards: Redefining already defined constructor for class B in D:\xampp\htdocs\test3\Class.php on line 8
this is __construct()
但仅调换下方法的位置结果却不一样:
<?phpclass X{//构造器public function __construct(){echo 'this is __construct()';}public function X(){echo 'this is X()';}public function other(){//do something}}$x = new X();?>
其实,从php5.3.3开始,与类名相同的方法不再做为类的构造方法,命名空间类也一样,要是使用的是php5.3.3以上的版本,就不能使用与类同名的方法作为构造方法了:
<?phpnamespace Foo;class Bar { public function Bar() { // PHP 5.3.0-5.3.2 是构造方法 // PHP 5.3.3 被当做是正常的方法使用 }}?>
如果非要在php5.3.3以上同时使用两个构造器,那么可以这样:
<?phpclass Y{//构造器public function __construct(){self::Y();}public function Y(){echo 'this is __construct() called Y()';// do init}public function other(){//do something}}$y = new Y();?>
页:
[1]