php面向对象(OOP)—不同php版本构造方法的继承和兼容
2015-06-03 15:07
591 查看
PHP4.x 版本:
PHP 4.x 的构造函数名与类名相同。
子类的构造函数名与子类名相同(废话)。
在子类里父类的构造函数不会自动执行。
要在子类里执行父类的构造函数,必须执行类似以下语句:
$this->[父类的构造函数名()]
class base1 {
function base1() {
echo 'this is base1 construct';
}
}
class class1 extends base1 {
function class1() {
$this -> base1();
echo 'this is class1 construct';
}
}
$c1 = new class1;
PHP5.x 版本:
PHP5.0 以上版本对类的功能进行了很大的扩充。类的构造函数统一命名为__construct()。
子类的构造函数名也是__construct()(也是废话)。
在子类里父类的构造函数会不会执行,分两种情况:
1、如子类不定义构造函数 __construct(),则父类的构造函数默认会被继承下来,且会自动执行。
2、如子类定义了构造函数 __construct(),因为构造函数名也是__construct(),所以子类的构造函数实际上是覆盖(override)了父类的构造函数。这时执行的是该子类的构造函数。
这时如果要在子类里执行父类的构造函数,必须执行类似以下语句:
parent::__construct();
class base2 {
function __construct() {
echo 'this is base2 construct';
}
function __destruct() {}
}
class class2 extends base2 {
function __construct() {
parent::__construct();
echo 'this is class2 construct';
}
}
注意 parent::__construct(); 语句不一定必须放在子类的构造函数中。放在子类的构造函数中仅仅保证了其在子类被实例化时自动执行。
PHP4.0 和 5.0 类构造函数的兼容问题:
在 PHP5.0 以上版本里,还兼容了 4.0 版本的构造函数的定义规则。如果同时定义了4.0的构造函数和 __construct()函数,则__construct() 函数优先。
为了使类代码同时兼容 PHP4.0 和 5.0,可以采取以下的方式:
class class3 {
function __construct() //for PHP5.0
{
echo 'this is class2 construct';
}
function class3() //for PHP4.0
{
$this -> __construct();
}
}
$c3 = new class3;
上面的内容引自"小炒花生米"大哥,谢谢大哥的分享。
PHP 4.x 的构造函数名与类名相同。
子类的构造函数名与子类名相同(废话)。
在子类里父类的构造函数不会自动执行。
要在子类里执行父类的构造函数,必须执行类似以下语句:
$this->[父类的构造函数名()]
class base1 {
function base1() {
echo 'this is base1 construct';
}
}
class class1 extends base1 {
function class1() {
$this -> base1();
echo 'this is class1 construct';
}
}
$c1 = new class1;
PHP5.x 版本:
PHP5.0 以上版本对类的功能进行了很大的扩充。类的构造函数统一命名为__construct()。
子类的构造函数名也是__construct()(也是废话)。
在子类里父类的构造函数会不会执行,分两种情况:
1、如子类不定义构造函数 __construct(),则父类的构造函数默认会被继承下来,且会自动执行。
2、如子类定义了构造函数 __construct(),因为构造函数名也是__construct(),所以子类的构造函数实际上是覆盖(override)了父类的构造函数。这时执行的是该子类的构造函数。
这时如果要在子类里执行父类的构造函数,必须执行类似以下语句:
parent::__construct();
class base2 {
function __construct() {
echo 'this is base2 construct';
}
function __destruct() {}
}
class class2 extends base2 {
function __construct() {
parent::__construct();
echo 'this is class2 construct';
}
}
注意 parent::__construct(); 语句不一定必须放在子类的构造函数中。放在子类的构造函数中仅仅保证了其在子类被实例化时自动执行。
PHP4.0 和 5.0 类构造函数的兼容问题:
在 PHP5.0 以上版本里,还兼容了 4.0 版本的构造函数的定义规则。如果同时定义了4.0的构造函数和 __construct()函数,则__construct() 函数优先。
为了使类代码同时兼容 PHP4.0 和 5.0,可以采取以下的方式:
class class3 {
function __construct() //for PHP5.0
{
echo 'this is class2 construct';
}
function class3() //for PHP4.0
{
$this -> __construct();
}
}
$c3 = new class3;
上面的内容引自"小炒花生米"大哥,谢谢大哥的分享。
相关文章推荐
- php Ajax 局部刷新
- GetPrivateProfileString和WritePrivateProfileString都是先打开文件操作完成后再关闭文件
- php面向对象(OOP)—构造方法与析构方法
- PHP函数大全
- PHP中spl_autoload_register函数的用法
- thinkphp 3.2+ 批量添加
- php面向对象(OOP)—调用成员和方法
- php发送邮件原理
- 更新页面缓存OutputCache
- ThinkPHP 中实现 Rewrite 模式
- thinkphp3.2定义多模块并设置默认模块
- 正好最近使用到了,记录PHP错误日志
- PHP LDAP连接微软活动目录进行身份验证
- php面向对象(OOP)—实例化对象
- TP 上传图片 (可上传多图)
- Laravel中创建Model
- TP分页 (3.1) — 其中,获取当页页需要在类库中加取方法
- php面向对象(OOP)—定义类
- Laravel常用的小知识
- Laravel访问网站页面空白