(PHP 4 >= 4.0.4, PHP 5)
call_user_func_array — パラメータの配列を指定してユーザ関数をコールする
param_arr にパラメータを指定して、 function で指定したユーザ定義関数をコールします。
コールする関数。
関数に渡すパラメータを指定する配列。
関数の結果、あるいはエラー時に FALSE を返します。
バージョン | 説明 |
---|---|
5.3.0 | オブジェクト指向のキーワード、たとえば parent や self などの処理方法が変わりました。 これまでは、ダブルコロン構文を使ってこれらをコールすると E_STRICT 警告が発生していました。静的コールと判断されたからです。 |
例1 call_user_func_array() の例
<?php
function foobar($arg, $arg2) {
echo __FUNCTION__, " got $arg and $arg2\n";
}
class foo {
function bar($arg, $arg2) {
echo __METHOD__, " got $arg and $arg2\n";
}
}
// foobar() 関数に引数を 2 つ渡してコールします
call_user_func_array("foobar", array("one", "two"));
// $foo->bar() メソッドに引数を 2 つ渡してコールします
$foo = new foo;
call_user_func_array(array($foo, "bar"), array("three", "four"));
?>
上の例の出力は、 たとえば以下のようになります。
foobar got one and two foo::bar got three and four
例2 call_user_func_array() での名前空間の使用法
<?php
namespace Foobar;
class Foo {
static public function test($name) {
print "Hello {$name}!\n";
}
}
// PHP 5.3.0 以降
call_user_func_array(__NAMESPACE__ .'\Foo::test', array('Hannes'));
// PHP 5.3.0 以降
call_user_func_array(array(__NAMESPACE__ .'\Foo', 'test'), array('Philip'));
?>
上の例の出力は、 たとえば以下のようになります。
Hello Hannes! Hello Philip!
例3 ラムダ関数の使用
<?php
$func = function($arg1, $arg2) {
return $arg1 * $arg2;
};
var_dump(call_user_func_array($func, array(2, 4))); /* PHP 5.3.0 以降 */
?>
上の例の出力は以下となります。
int(8)
注意:
param_arr 内で参照される変数は、 関数に参照渡しされます。これは、 その関数がパラメータを参照渡しで受け取ることを期待しているかどうかにかかわらず同じです。 この形式でコール時に参照渡しをしても、廃止予定であるという notice は発生しません。とはいえ、それが廃止予定であることに変わりはなく、 次のバージョンの PHP では使えなくなるでしょう。 さらに、この形式は PHP の組み込み関数には適用できません。 組み込み関数については関数のシグネチャが優先されます。 参照渡しを期待しているところに値で渡すと警告が発生し、 call_user_func() は FALSE を返します (渡した値の参照カウンタが 1 である場合は、これはあてはまりません)。
注意:
call_user_func() や call_user_func_array() で登録されたコールバックは、 前のコールバックからスローされた例外がキャッチされていない場合はコールされません。