(PHP 4, PHP 5)
call_user_func — 最初の引数で指定したユーザ関数をコールする
パラメータ functionで指定した ユーザ定義のコールバック関数をコールします。
コールする関数。このパラメータに array($classname, $methodname) を指定することにより、 クラスメソッドも静的にコールすることができます。 さらに、オブジェクトのインスタンスのクラスメソッドをコールするには、 array($objectinstance, $methodname) をこのパラメータに渡します。
この関数に渡す、ゼロ個以上のパラメータ。
注意:
call_user_func() のパラメータは 参照渡しではないことに注意しましょう。
例1 call_user_func() の例と参照
<?php
error_reporting(E_ALL);
function increment(&$var)
{
$var++;
}
$a = 0;
call_user_func('increment', $a);
echo $a."\n";
call_user_func_array('increment', array(&$a)); // PHP 5.3 より前のバージョンでは、このようにしてもかまいません
echo $a."\n";
?>上の例の出力は以下となります。
0 1
関数の結果、あるいはエラー時に FALSE を返します。
バージョン | 説明 |
---|---|
5.3.0 | オブジェクト指向のキーワード、たとえば parent や self などの処理方法が変わりました。 これまでは、ダブルコロン構文を使ってこれらをコールすると E_STRICT 警告が発生していました。静的コールと判断されたからです。 |
例2 call_user_func() の例
<?php
function barber($type)
{
echo "$type ですね、わかりました。\n";
}
call_user_func('barber', "マッシュルームカット");
call_user_func('barber', "髭剃り");
?>
上の例の出力は以下となります。
マッシュルームカット ですね、わかりました。 髭剃り ですね、わかりました。
例3 名前空間を使用した call_user_func()
<?php
namespace 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() でのクラスメソッドの使用
<?php
class 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() でのラムダ関数の使用
<?php
call_user_func(function($arg) { print "[$arg]\n"; }, 'test'); /* PHP 5.3.0 以降 */
?>
上の例の出力は以下となります。
[test]
注意:
call_user_func() や call_user_func_array() で登録されたコールバックは、 前のコールバックからスローされた例外がキャッチされていない場合はコールされません。