给定一个基类,我有一些必须在某个方法之前和之后运行的逻辑,它在不同的派生类中采用了截然不同的参数.
举个例子:
abstract class Base{
public function pre(){ print "Runing Base::pre()\n"; }
public function pos(){ print "Runing Base::post()\n"; }
abstract public function doIt();
}
class Cheating extends Base
{
public function doIt(){
$this->pre();
print "Doing it the cheating way\n";
$this->pos();
}
}
但我真正喜欢做的是:
class Alpha extends Base
{
public function doIt($x, $y){
print "Doing it in Alpha with x=$x, y=$y";
}
}
class Beta extends Base
{
public function doIt($z){
print "Doing it in Alpha with z=$z";
}
}
并且有一些方法可以始终运行pre和pos方法,而无需更改doIt方法本身.
显而易见的方式,应该是在所有Base的派生中是同质的,如下所示:
abstract class Base
{
public function pre(){ print "Runing Base::pre()\n"; }
public function pos(){ print "Runing Base::post()\n"; }
public function process($a,$b){
$this->pre();
$this->doIt($a,$b);
$this->pos();
}
abstract public function doIt();
}
class Wishful extends Base
{
public function doIt($a, $b){
print "Doing it the Wishful way with a=$a, b=$b\n";
}
}
问题在于,由于我们在每个doIt实现上都有不同数量和类型的参数,因此实际上并没有解决问题.
这听起来像是“钩子”的情况 – 如何实现这些?或者任何其他解决问题的正当方式……我相信应该有一种更简单的方法,我只是错过了 – 可能在圈子中思考错误的事情.
谢谢!
最佳答案 使用变量参数调用可以使用:
http://php.net/manual/en/function.call-user-func-array.php.将$this作为对象传递.
获取参数有点棘手,但可以使用__call:http://www.php.net/manual/en/language.oop5.overloading.php#language.oop5.overloading.methods完成