In the case of call_user_func_array(), if you were to pass around an anonymous function and reference $this within the anonymous function, $this will faithfully refer to the class in the context in which the function was defined. Using ReflectionFunction::invokeArgs() does not seem to retain its original context--yeah, even if you bind the anonymous function before invoking. I recommend call_user_func_array() where context is a concern.ReflectionFunction::invokeArgs
Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.
ReflectionFunction::invokeArgs
Референца за `reflectionfunction.invokeargs.php` со подобрена типографија и навигација.
ReflectionFunction::invokeArgs
(PHP 5 >= 5.1.2, PHP 7, PHP 8)
ReflectionFunction::invokeArgs — Invokes function args
= NULL
Invokes the function and pass its arguments as array.
Параметри
args-
The passed arguments to the function as an array, much like call_user_func_array() works.
Вратени вредности
Returns the result of the invoked function
Дневник на промени
| Верзија | = NULL |
|---|---|
| 8.0.0 |
args клучевите сега ќе се толкуваат како имиња на параметри, наместо да се игнорираат тивко.
|
Примери
Пример #1 ReflectionFunction::invokeArgs() example
<?php
function title($title, $name)
{
return sprintf("%s. %s\r\n", $title, $name);
}
$function = new ReflectionFunction('title');
echo $function->invokeArgs(array('Dr', 'Phil'));
?>Пример #1 Пример што покажува затворачка ознака што го опфаќа последниот нов ред
Dr. Phil
Пример #2 ReflectionFunction::invokeArgs() with references example
<?php
function get_false_conditions(array $conditions, array &$false_conditions)
{
foreach ($conditions as $condition) {
if (!$condition) {
$false_conditions[] = $condition;
}
}
}
$function_ref = new ReflectionFunction('get_false_conditions');
$conditions = array(true, false, -1, 0, 1);
$false_conditions = array();
$function_ref->invokeArgs(array($conditions, &$false_conditions));
var_dump($false_conditions);
?>Пример #1 Пример што покажува затворачка ознака што го опфаќа последниот нов ред
array(2) {
[0]=>
bool(false)
[1]=>
int(0)
}
Белешки
Забелешка:
If the function has arguments that need to be references, then they must be references in the passed argument list.
Види Исто така
- ReflectionFunction::invoke() - Повикува функција
- - Враќа низа што содржи список со аргументи на функција ReflectionFunctionAbstract::getNumberOfParameters()
- __invoke()
- call_user_func_array() - Повикајте повик со низа од параметри
Белешки од корисници 2 забелешки
I encountered a weird problem with ReflectionFunction, described in ticket 44139 of PHP Bugs.
If for some reason you need to call with invoke, or invokeArgs, a function like array_unshift (that accepts internally the array by reference) you could use this code to avoid the generated warning or fatal error.
<?php
function unshift(){
$ref = new ReflectionFunction('array_unshift');
$arguments = func_get_args();
return $ref->invokeArgs(array_merge(array(&$this->arr), $arguments));
}
?>
I don't know about performances (you can create an array manually too, starting from array(&$this->something) and adding arguments). However, it seems to work correctly without problems, at least until the send by reference will be usable with one single value ...