PHP学习笔记——延迟静态绑定

使用场景

先来观察如下代码:php

abstract class base {
    //do sth
}

class aClass extends base{
    public static function create(){
        return new aClass();
    } 
}

class bClass extends base{
    public static function create(){
        return new bClass();
    }
}
var_dump(aClass::create());
var_dump(bClass::create());

输出:oop

object(aClass)#1 (0) { } object(bClass)#1 (0) { }code

以上aClass和bClass继承于base这个抽象类,可是在两个子类中同时实现了create()这个静态方法。听从oop思想,这种重复代码应该放在base这个父类中实现。对象

改进代码

abstract class base {
    public static function create(){
        return new self();
    } 
}

class aClass extends base{

}

class bClass extends base{

}

var_dump(aClass::create());
var_dump(bClass::create());

如今的代码看起来好像已经符合咱们以前的想法,将create()方法放在父类里共用了,那咱们来运行下看会发生什么。继承

Cannot instantiate abstract class base in ...io

很遗憾,代码好像并无按照咱们预想的那样去运行,父类中的self()被解析为base这个父类,并不是继承与他的子类。因而为了解决这个问题,php5.3中引入了延迟静态绑定这个概念。function

延迟静态绑定

abstract class base {
    public static function create(){
        return new static();
    } 
}

class aClass extends base{

}

class bClass extends base{

}

var_dump(aClass::create());
var_dump(bClass::create());

这个代码与以前的几乎一致,不一样点在于将self换成了static这个关键字,static会解析为子类,而非父类,这样就能够解决上面遇到的问题,这就是php的延迟静态绑定。class

最后,运行一下代码,获得了最终想要的结果。object

object(aClass)#1 (0) { } object(bClass)#1 (0) { }方法

[参考文献]深刻PHP面向对象、模式与实践

相关文章
相关标签/搜索