我首先对grrbrr404说“谢谢”。他给了我一些想法,让我开始朝着正确的方向发展。
我终于解决该解决方案是以下几点:
function inherit_this() {
$bt = debug_backtrace();
call_user_func(array($this, get_parent_class($bt[1]['class']) . '::do_something'));
}
这不是漂亮(我特别讨厌呼吁debug_backtrace()
此),但它一直设置到这个$对象上下文,并处理情况该方法从对象层次结构中间的某个方法调用。
对于那些发现我的例子令人困惑和/或想知道“为什么你想要这样做?”我很抱歉,并提供了下面的附加例子,这有希望更具说明性,更接近原始问题。这是相当长的时间,但希望说明为什么我关心保持$这个设置正确,也说明了为什么我不能硬编码任何特定的类名或使用$ this-> method()。避免无限循环始终是我的首要任务。 :-)
class class1_required_type { }
class class2_required_type { }
class class3_required_type { }
class class4_required_type { }
class class1 {
protected $data = array();
protected function checkType($name, $value, $requiredType) {
print "In class1::checkType()\n";
if (get_class($value) === $requiredType) {
$backtrace = debug_backtrace();
call_user_func(array($this, get_parent_class($backtrace[1]['class']) . "::mySet"), $name, $value);
} else {
throw new Exception(get_class($this) . "::mySet('" . $name . "') requires an object of type '" . $requiredType . "', but got '" . get_class($value) . "'");
}
}
function mySet($name, $value) {
print "In class1::mySet()\n";
if ($name === 'class1_field') {
$this->checkType($name, $value, 'class1_required_type');
} else {
$this->data[$name] = $value;
}
}
function dump() {
foreach ($this->data as $key => $value) {
print "$key: " . get_class($value) . "\n";
}
}
}
class class2 extends class1 {
function mySet($name, $value) {
print "In class2::mySet()\n";
if ($name === 'class2_field') {
$this->checkType($name, $value, 'class2_required_type');
} else {
parent::mySet($name, $value);
}
}
}
class class3 extends class2 {
function mySet($name, $value) {
print "In class3::mySet()\n";
if ($name === 'class3_field') {
$this->checkType($name, $value, 'class3_required_type');
} else {
parent::mySet($name, $value);
}
}
}
class class4 extends class3 {
function mySet($name, $value) {
print "In class4::mySet()\n";
if ($name === 'class4_field') {
$this->checkType($name, $value, 'class4_required_type');
} else {
parent::mySet($name, $value);
}
}
}
$obj = new class4;
$obj->mySet('class3_field', new class3_required_type);
$obj->dump();
我试图避免“checkType()”函数的重复,但仍提供即使在层次结构得到任意大的正确的行为。
更为优雅的解决方案当然是最受欢迎的。
你不能使用php5,然后做一个私有的base_class方法吗?这意味着继承类不能覆盖该方法。 – smack0007
也许,但我实际上是想让interiting类重写方法。这实际上是原始代码的大部分重点。我可能需要重写这个例子,但它会更长。 –