延迟静态绑定——static
起因
乍听之下这名词很新鲜,各位听众继续往下走就知道其实你们是见过的。最近在看《PHP面向对象实践与设计》中讲到了延迟静态绑定
static
的用法,特此来和大家分享,应该是比较简单的内容吧。
直接上代码
/**
* 功能:子类(学生类,老师类)实例化自己的类
*
*/
abstract class People
{
}
class Student extends People {
public static function create()
{
return new self();
}
}
class Teacher extends People {
public static function create()
{
return new self();
}
}
var_dump(Student::create());
一般情况下,咱们首先想到的是上面的写法,可以我们程序员是“懒惰”的,不可以可以在父类的只写一个create()
方法呢,那么大家会首先想到的self()
关键字吧(嘿嘿,至少我当时是这么想的),那我们是实现一下看看:
/**
* 功能:子类实例化自己的类
*
*/
abstract class People
{
public static function create()
{
return new self();
}
}
class Student extends People {
}
class Teacher extends People {
}
var_dump(Student::create());
结果:Fatal error: Uncaught Error: Cannot instantiate abstract class People
。
这个时候就是我们的主角static
登场的时候,修改代码如下:
/**
* 功能:子类实例化自己的类
*
*/
abstract class People
{
public static function create()
{
return new static();
}
}
class Student extends People {
}
class Teacher extends People {
}
var_dump(Student::create());
结果: 很完美的输出了Student类。
结论
哦,原来如此,是因为self
关键字指向是当前类(即所在的类)的指针,它所在的People
是抽象类,不能实例化的,他并没有想咱们所想的那样,指向调用者本身(即Student类)。而static
关键字,延迟静态绑定,它所指向的即使调用者本身 (即Student类)。
本作品采用《CC 协议》,转载必须注明作者和本文链接
推荐文章: