在PHP中,我可以使用普通函数作为变量而没有问题,但我还没有弄清楚如何使用静态方法.我只是错过了正确的语法,或者这是不可能的?
(编辑:第一个建议的答案似乎不起作用.我已扩展我的示例以显示返回的错误.)
function foo1($a,$b) { return $a/$b; } class Bar { static function foo2($a,$b) { return $a/$b; } public function UseReferences() { // WORKS FINE: $fn = foo1; print $fn(1,1); // WORKS FINE: print self::foo2(2,1); print Bar::foo2(3,1); // DOES NOT WORK ... error: Undefined class constant 'foo2' //$fn = self::foo2; //print $fn(4,1); // DOES NOT WORK ... error: Call to undefined function self::foo2() //$fn = 'self::foo2'; //print $fn(5,1); // DOES NOT WORK ... error: Call to undefined function Bar::foo2() //$fn = 'Bar::foo2'; //print $fn(5,1); } } $x = new Bar(); $x->UseReferences();
(我使用的是PHP v5.2.6 - 答案会根据版本而改变吗?)
PHP将回调作为字符串处理,而不是函数指针.您的第一个测试工作的原因是因为PHP解释器将foo1假定为字符串.如果启用了E_NOTICE级别错误,您应该看到相应的证据.
"使用未定义的常量foo1 - 假设'foo1'"
不幸的是,你不能以这种方式调用静态方法.范围(类)是相关的,因此您需要使用call_user_func.
UseReferences();
在php 5.2中,您可以在静态调用中使用变量作为方法名称,但是要使用变量作为类名,您必须使用BaileyP所描述的回调.
但是,从php 5.3开始,您可以在静态调用中使用变量作为类名.所以:
class Bar { public static function foo2($a,$b) { return $a/$b; } public function UseReferences() { $method = 'foo2'; print Bar::$method(6,2); // works in php 5.2.6 $class = 'Bar'; print $class::$method(6,2); // works in php 5.3 } } $b = new Bar; $b->UseReferences(); ?>