找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 868|回复: 0
打印 上一主题 下一主题

简单谈谈php延迟静态绑定

[复制链接]

2560

主题

2560

帖子

7622

积分

论坛元老

Rank: 8Rank: 8

积分
7622
跳转到指定楼层
楼主
发表于 2018-2-14 05:39:19 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            使用场景
先来观察以下代码:
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());
输出:
object(aClass)#1 (0) { } object(bClass)#1 (0) { }
以上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 ...
很遗憾,代码好像并没有按照我们预想的那样去运行,父类中的self()被解析为base这个父类,并非继承与他的子类。于是为了解决这个问题,php5.3中引入了延迟静态绑定这个概念。
延迟静态绑定
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的延迟静态绑定。
最后,运行一下代码,得到了最终想要的结果。
object(aClass)#1 (0) { } object(bClass)#1 (0) { }
            
            
您可能感兴趣的文章:
  • windows下升级PHP到5.3.3的过程及注意事项
  • 深入理解C++的动态绑定与静态绑定的应用详解
  • PHP延迟静态绑定示例分享
  • PHP5.3安装Zend Guard Loader图文教程
  • Java中的静态绑定和动态绑定详细介绍
  • php延迟静态绑定实例分析
  • PHP5.3以上版本安装ZendOptimizer扩展
  • PHP面向对象之后期静态绑定功能介绍
  • 理解Java中的静态绑定和动态绑定
  • PHP Static延迟静态绑定用法分析
  • php5.3后静态绑定用法详解
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端