在什么条件下PHP 7的自我引用了基类?
发布时间:2020-12-13 18:01:28 所属栏目:PHP教程 来源:网络整理
导读:如 on Reddit’s LOL PHP sub所述,PHP 7在引用self时可以使用扩展类或基类,而PHP 5总是引用扩展类. ?phpclass Foo { const A = "FooA"; const B = self::A . self::C; const C = "FooC";}class Bar extends Foo { const A = "BarA"; const C = "BarC";}var_d
如
on Reddit’s LOL PHP sub所述,PHP 7在引用self时可以使用扩展类或基类,而PHP 5总是引用扩展类.
<?php class Foo { const A = "FooA"; const B = self::A . self::C; const C = "FooC"; } class Bar extends Foo { const A = "BarA"; const C = "BarC"; } var_dump(Bar::B); Try it online PHP 5 string(8) "BarABarC" PHP 7 string(8) "FooABarC" PHP 7的行为特别令人担忧,因为似乎没有任何简单的规则来知道self何时引用基类或扩展类.什么是确定哪个类自我将在PHP 7中引用的规则?
self ::应该始终引用它所使用的类(注意PHP 5的行为也是错误的.)
这是在7.1.4中的bug,fixed,它适用于在类常量中解析self ::和parent ::. 基本上: const B = self::A . self::C; self :: C此时仍然未知,并且推迟了解决方案.在最终解决时,遗憾的是失去了适当的范围. 问题也比简单的基础扩展和扩展更加微妙,因为你可以从不同的扩展类中得到一个值.例如.: https://3v4l.org/cY1I0 class A { const selfN = self::N; const N = 'A'; } class B extends A { const N = 'B'; } class C extends A { const N = 'C'; } var_dump(B::selfN); // A var_dump(C::selfN); // A 在PHP 7.0.0到7.1.3中,这输出: string(1) "B" string(1) "B" 虽然如果你交换它: https://3v4l.org/RltQj var_dump(C::selfN); // A var_dump(B::selfN); // A 你会得到: string(1) "C" string(1) "C" 要在受影响的版本中避免这种情况,请使用类名而不是类::常量定义中的self :: const selfN = A :: N (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |