call_user_func_array

函數說明

(PHP 4 >= 4.0.4, PHP 5)
call_user_func_array - 用一個數組做爲參數調用一個回調函數.返回值爲回調函數執行的結果或者爲false(回調函數執行有error時). [1]

函數定義

mixed call_user_func_array(callback $function , array $param_arr )
把$param_arr數組中的每一個值做爲參數在$function裏執行。

功能

用於屢次使用一個函數。參數能夠在後面的數組中定義。

參數

要傳遞參數給函數,做爲一個索引數組。

版本說明

5.3.0對象的解釋像父性的關鍵詞和自我改變。在此以前,稱他們使用雙冒號語法將發出一個E_STRICT警告,由於它們是靜態的解釋。

提示註釋

param_arr中引用的變量被傳遞給函數的參考,不管各自的功能參數,以指望經過引用傳遞。這種通話時經過引用傳遞的形式並不過期發出的通知,但它仍不失爲過期了,而且極可能會在下一版本的PHP中刪除。此外,這並不適用於內部函數,該函數的簽名很榮幸。按值傳遞函數時預計,警告,有call_user_func()返回FALSE參數按引用的結果(不適用,若是傳遞的值有一個引用計數=1)。如call_user_func()和call_user_func_array()不會被調用,若是有一個未捕獲的異常拋出在先前的回調函數。

實例說明

例-1
<?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";
}
}
// Call the foobar() function with 2 arguments
call_user_func_array("foobar", array("one", "two"));
// Call the $foo->bar() method with 2 arguments
$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";
}
}
// As of PHP 5.3.0
call_user_func_array(__NAMESPACE__ .'\Foo::test', array('Hannes'));
// As of 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))); /* As of PHP 5.3.0 */
?>
將輸出:
int(8)
本站公眾號
   歡迎關注本站公眾號,獲取更多信息