我已经读过为什么PHP5.2不允许抽象静态类方法?以及如何强制实现受保护的静态函数-第二个与我的情况非常相似-但我仍然没有答案。基本上,我想保证,我的抽象类的每个子类都有受保护的静态方法的实现,而没有实现它,因为这没有意义,并且因为缺乏关键信息。此外,它必须是静态的(因为调用者方法是静态的,它没有上下文)和受保护的(所以我不能使用接口,我不希望任何人直接调用它),并且它将被后期静态绑定调用。有什么想法吗?
下面的虚拟代码来阐明我的案例:
abstract class BaseClass {
public static function foo() {
// some common stuff
static::bar();
// rest of common stuff
}
public function whoooaaa($condition) {
if ($condition) {
AClass::foo();
} else {
BClass::foo();
}
}
}
class AClass extends BaseClass {
protected static function bar() {
// do something
}
}
class BClass extends BaseClass {
protected static function bar() {
// do something else
}
}
// end somewhere else in my code, two constructions, both used:
AClass::foo();
// ....
$baseClassInheritedInstance->whoooaaa($variableCondition);
我唯一的解决方案,丑陋的一个,是在基类中实现虚拟保护的静态方法并抛出一个泛型异常,这样它就必须通过继承来实现。
您可以添加一个静态工厂来填充临时对象的上下文。
class Factory() {
public static getObject($condition) {
$object = $condition ? new A() : new B();
// you can fill context here and/or use singleton/cache
return $object;
}
}
abstract class Base {
abstract function concreteMethod();
}
class A extends Base {...}
class B extends Base {...}