21,891
社区成员
发帖
与我相关
我的任务
分享
class father{
public $a;
function __construct(){
$this->a = 3;
}
}
include 'fatherClass.php';
$son = new son();
$son -> sonFun();
class son extends father{
function sonFun(){
echo 222;
}
}
include 'fatherClass.php';
class son extends father{
function sonFun(){
echo 222;
}
}
$son = new son();
$son -> sonFun();
他解释了类继承的编译机制和多重继承的BUG,能解决楼主的第一个疑问
2、如果把fatherClass里的内容直接代替include语句,运行正确;
这个说明include(require?xxxxxx_once?)是在执行期才运行的,编译时压根没鸟它
总结下,zend读取php脚本后,如果发现干净的无继承的类,就先建立出来(接近汇编的'类'结构而不是php的'类'),如果发现有继承类并且他的父类已存在,同样建立,其他代码继续编译。这时php脚本变成了opcode。执行时按顺序运行代码,比如include读取其他php脚本(opcode),复杂继承类的建立,执行汇编码的阶段不会智能识别类定义,只会严格按照php代码的顺序执行。
如果我的想法是对的倒是可以解释楼主的疑问
为了适应各种设计模式,我觉得编译阶段智能一点很好啊~
甚至以后的php版本可能做到html语法解释器那样的智能补全高容错
php提供了opcode缓存扩展,不光是多行扫描的词法解释,再耽误性能的编译机制也有办法解决~更消除了OOP的多文件带来的磁盘IO开销