在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();
Run Code Online (Sandbox Code Playgroud)
(我使用的是PHP v5.2.6 - 答案会根据版本而改变吗?)
Pet*_*ley 28
PHP将回调作为字符串处理,而不是函数指针.您的第一个测试工作的原因是因为PHP解释器将foo1假定为字符串.如果启用了E_NOTICE级别错误,您应该看到相应的证据.
"使用未定义的常量foo1 - 假设'foo1'"
不幸的是,你不能以这种方式调用静态方法.范围(类)是相关的,因此您需要使用call_user_func.
<?php
function foo1($a,$b) { return $a/$b; }
class Bar
{
public static function foo2($a,$b) { return $a/$b; }
public function UseReferences()
{
$fn = 'foo1';
echo $fn(6,3);
$fn = array( 'self', 'foo2' );
print call_user_func( $fn, 6, 2 );
}
}
$b = new Bar;
$b->UseReferences();
Run Code Online (Sandbox Code Playgroud)
在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();
?>
Run Code Online (Sandbox Code Playgroud)
您可以使用静态方法的全名,包括命名空间。
<?php
function foo($method)
{
return $method('argument');
}
foo('YourClass::staticMethod');
foo('Namespace\YourClass::staticMethod');
Run Code Online (Sandbox Code Playgroud)
name 数组array('YourClass', 'staticMethod')等于它。但我认为字符串可能更易于阅读。