call_user_func
(PHP 4, PHP 5, PHP 7)
call_user_func — 最初の引数で指定したコールバック関数をコールする
説明
パラメータ callback
で指定したユーザー定義のコールバック関数をコールします。
パラメータ
callback
コールする callable。
args
コールバック関数に渡す、ゼロ個以上のパラメータ。
注意:
call_user_func() のパラメータは 参照渡しではないことに注意しましょう。
例1 call_user_func() の例と参照
<?phperror_reporting(E_ALL);function increment(&$var){ $var++;}$a = 0;call_user_func('increment', $a);echo $a."\n";// このようにしてもかまいませんcall_user_func_array('increment', array(&$a));echo $a."\n";?>
上の例の出力は以下となります。
Warning: Parameter 1 to increment() expected to be a reference, value given in … 0 1
返り値
コールバック関数の結果を返します。
例
例2 call_user_func() の例
<?phpfunction barber($type){ echo "$type ですね、わかりました。\n";}call_user_func('barber', "マッシュルームカット");call_user_func('barber', "髭剃り");?>
上の例の出力は以下となります。
マッシュルームカット ですね、わかりました。 髭剃り ですね、わかりました。
例3 名前空間を使用した call_user_func()
<?phpnamespace Foobar;class Foo { static public function test() { print "Hello world!\n"; }}call_user_func(__NAMESPACE__ .'\Foo::test'); // PHP 5.3.0 以降call_user_func(array(__NAMESPACE__ .'\Foo', 'test')); // PHP 5.3.0 以降?>
上の例の出力は以下となります。
Hello world! Hello world!
例4 call_user_func() でのクラスメソッドの使用
<?phpclass myclass { static function say_hello() { echo "Hello!\n"; }}$classname = "myclass";call_user_func(array($classname, 'say_hello'));call_user_func($classname .'::say_hello'); // 5.2.3 以降$myobject = new myclass();call_user_func(array($myobject, 'say_hello'));?>
上の例の出力は以下となります。
Hello! Hello! Hello!
例5 call_user_func() でのラムダ関数の使用
<?phpcall_user_func(function($arg) { print "[$arg]\n"; }, 'test'); /* PHP 5.3.0 以降 */?>
上の例の出力は以下となります。
[test]
注意
注意:
call_user_func() や call_user_func_array() で登録されたコールバックは、 前のコールバックからスローされた例外がキャッチされていない場合はコールされません。
参考
- call_user_func_array() - パラメータの配列を指定してコールバック関数をコールする
- is_callable() - 引数が、関数としてコール可能な構造であるかどうかを調べる
- ReflectionFunction::invoke() - 関数を起動する
- ReflectionMethod::invoke() - 実行する