首页 / PHP / php延迟绑定和非延迟绑定解析
php延迟绑定和非延迟绑定解析
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了php延迟绑定和非延迟绑定解析,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3119字,纯文字阅读大概需要5分钟。
内容图文
php版本: php5.6延迟绑定有: get_class($this), get_called_class(), new static(), static::
非延迟绑定有:get_class(), __CLASS__, new self(), self::
使用new static()时
<?phpclass NewStatic{ //该类的实例 private $newStatic; //判断$newStatic是否为空,为空则实例化自身并存入$newStatic public function init() { if (empty($this -> newStatic)) { $this -> newStatic = new static(); echo "该类已初始化"; } else { $this -> newStatic -> exec(); } } //该类的执行方法 public function exec() { echo "该类NewStatic已执行"; } }class Sub extends NewStatic{ //覆盖父类中的exec方法,用于区分 public function exec() { echo "该类Sub已执行"; } }echo "<h3>NewStatic的测试结果</h3>";$newStatic = new NewStatic();echo "第一次执行初始化的结果:<br>";$newStatic -> init(); //输出结果: 该类已初始化echo "<br>第二次执行初始化的结果:<br>";$newStatic -> init(); //输出结果: 该类NewStatic已执行echo "<h3>NewStatic的子类Sub的测试结果</h3>";$sub = new Sub();echo "第一次执行初始化的结果:<br>";$sub -> init(); // 输出结果: 该类已初始化echo "<br>第二次执行初始化的结果:<br>";$sub -> init(); //输出结果: 该类Sub已执行
将static替换为self
<?phpclass NewStatic{ //该类的实例 private $newStatic; //判断$newStatic是否为空,为空则实例化自身并存入$newStatic public function init() { if (empty($this -> newStatic)) { $this -> newStatic = new self(); //修改此处的static为self echo "该类已初始化"; } else { $this -> newStatic -> exec(); } } //该类的执行方法 public function exec() { echo "该类NewStatic已执行"; } }class Sub extends NewStatic{ //覆盖父类中的exec方法,用于区分 public function exec() { echo "该类Sub已执行"; } }echo "<h3>NewStatic的测试结果</h3>";$newStatic = new NewStatic();echo "第一次执行初始化的结果:<br>";$newStatic -> init(); //输出结果: 该类已初始化echo "<br>第二次执行初始化的结果:<br>";$newStatic -> init(); //输出结果: 该类NewStatic已执行echo "<h3>NewStatic的子类Sub的测试结果</h3>";$sub = new Sub();echo "第一次执行初始化的结果:<br>";$sub -> init(); // 输出结果: 该类已初始化echo "<br>第二次执行初始化的结果:<br>";$sub -> init(); //输出结果: 该类NewStatic已执行 此处输出的结果发生了变化
结论:
如果在子类中调用父类中含有new static()的方法时,它实例化子类,但是如果是父类中使用的是new self()的话,那么实例化的就是父类了,new self()永远指向定义的那个类,而new static() 会绑定调用时的那个类(延迟绑定)这就是new static()和new self()的区别。这个区别实际上跟static::和self::的区别是一样的,使用static::调用静态方法时调用的是延迟绑定后的类的静态方法,而self::指向定义的静态类的方法 另外要补充的一点new self()等同于如下写法:$class = get_class(); //注意:这里的get_class()里边没有传递参数$obj = new $class(); 或者$class = __CLASS__;$obj = new $class();new static()等同于如下写法:$class = get_called_class();$obj = new $class(); 或者$class = get_class($this); // 这里get_class()有没有传递参数效果是不一样的,跟这个函数本身的特性有关$obj = new $class();
相关推荐:
php中关于静态延迟绑定与普通静态效率的对比详解
PHP中父类与子类的晚期绑定/延迟绑定
PHP 面向对象程序设计(oop)学习笔记 (二) - 静态变量的属性和方法及延迟绑定_php实例
以上就是php延迟绑定和非延迟绑定解析的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是互联网集市为您收集整理的php延迟绑定和非延迟绑定解析全部内容,希望文章能够帮你解决php延迟绑定和非延迟绑定解析所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。