Funciones de Manejo de Funciones
PHP Manual

call_user_func_array

(PHP 4 >= 4.0.4, PHP 5)

call_user_func_arrayLlamar a una función de usuario dada con una matriz de parámetros

Descripción

mixed call_user_func_array ( callback $function , array $param_arr )

Llama a la función definida por el usuario dada por function con los parámetros de param_arr.

Parámetros

function

La función que va a ser llamada.

param_arr

Los parámetros a pasar a la función, como matriz indexada.

Valores devueltos

Devuelve el resultado de la función, o FALSE en caso de error.

Historial de cambios

Versión Descripción
5.3.0 La interpretación de palabras clave orientadas a objetos como parent y self ha cambiado. Anteriormente al llamarlas usando la sintaxis de dobles dos puntos emitiría una advertencia E_STRICT porque eran interpretadas como estáticas.

Ejemplos

Example #1 Ejemplo de call_user_func_array()

<?php
function foobar($arg$arg2) {
    echo 
__FUNCTION__" obtuvo $arg y $arg2\n";
}
class 
foo {
    function 
bar($arg$arg2) {
        echo 
__METHOD__" obtuvo $arg y $arg2\n";
    }
}


// Llamar a la función foobar() con 2 argumentos
call_user_func_array("foobar", array("uno""dos"));

// Llamar al método $foo->bar() con 2 argumentos
$foo = new foo;
call_user_func_array(array($foo"bar"), array("tres""cuatro"));
?>

El resultado del ejemplo sería algo similar a:

foobar obtuvo uno y dos
foo::bar obtuvo tres y cuatro

Example #2 call_user_func_array() usando un nombre de espacio de nombres

<?php

namespace Foobar;

class 
Foo {
    static public function 
prueba($nombre) {
        print 
"¡Hola {$nombre}!\n";
    }
}

// A partir de PHP 5.3.0
call_user_func_array(__NAMESPACE__ .'\Foo::prueba', array('Gema'));

// A partir de PHP 5.3.0
call_user_func_array(array(__NAMESPACE__ .'\Foo''prueba'), array('Pedro'));

?>

El resultado del ejemplo sería algo similar a:

¡Hola Gema!
¡Hola Pedro!

Example #3 Usar una función lambda

<?php

$func 
= function($arg1$arg2) {
    return 
$arg1 $arg2;
};

var_dump(call_user_func_array($func, array(24))); /* A partir de PHP 5.3.0 */

?>

El resultado del ejemplo sería:

int(8)

Notas

Note:

Las variables referenciadas en param_arr son pasadas a la función por referencia, si tener en cuenta si la función espera que el parámetro respectivo sea pasado por referencia. Esta forma de paso por referncia en tiempo de llamda no emite un aviso de obsoleta, pero, no obstante, está obsoleta, y lo más seguro es que sea eliminada en la siguiente versión de PHP. Además, esto no se aplica a funciones internas, para las que la firma de la funcion es aceptada. Pasar por valor cuando la función espera un parámetro por referencia resulta en una advertencia, y call_user_func() devolverá FALSE (no se aplica si el valor pasado tiene una cómputo de referencia = 1).

Note:

Las funciones de retorno de llamada que se registran con funciones como call_user_func() y call_user_func_array() no se llamarán si se produce una excepción en la función de retorno previa.

Ver también


Funciones de Manejo de Funciones
PHP Manual