func_get_args

(PHP 4, PHP 5)

func_get_argsRetourne les arguments d'une fonction sous la forme d'un tableau

Description

array func_get_args ( void )

Récupère les arguments d'une fonction sous la forme d'un tableau.

func_get_arg() peut être utilisé conjointement à func_num_args() et func_get_args() pour permettre aux fonctions utilisateurs d'accepter un nombre variable d'arguments.

Valeurs de retour

Retourne un tableau dont chaque élément est une copie du membre correspondant de la liste d'arguments de la fonction.

Historique

Version Description
5.3.0 Cette fonction peut maintenant être utilisée dans des listes de paramètres.
5.3.0 Si cette fonction est appelée dans un fichier inclus avec include ou require logé dans une fonction, elle génèrera une alerte et retournera FALSE.

Erreurs / Exceptions

Générera une alerte si elle est appelée hors d'une fonction.

Exemples

Exemple #1 Exemple avec func_get_args()

<?php
function foo()
{
	$numargs = func_num_args();
	echo "Nombre d'arguments : $numargs<br />\n";
	if ($numargs >= 2) {
		echo "Le second argument est : " . func_get_arg(1) . "<br />\n";
	}
	$arg_list = func_get_args();
	for ($i = 0; $i < $numargs; $i++) {
		echo "L'argument $i est : " . $arg_list[$i] . "<br />\n";
	}
}

foo(1, 2, 3);
?>
test.php
<?php
function foo() {
	include './fga.inc';
}

foo('Argument 1', 'Argument 2');
?>

fga.inc
<?php

$args = func_get_args();
var_export($args);

?>
<?php
function byVal($arg) {
	echo 'Tel que passé	 : ', var_export(func_get_args()), PHP_EOL;
	$arg = 'baz';
	echo 'Après changement  : ', var_export(func_get_args()), PHP_EOL;
}

function byRef(&$arg) {
	echo 'Tel que passé	 : ', var_export(func_get_args()), PHP_EOL;
	$arg = 'baz';
	echo 'Après changement  : ', var_export(func_get_args()), PHP_EOL;
}

$arg = 'bar';
byVal($arg);
byRef($arg);
?>

L'exemple ci-dessus va afficher :


Tel que passé : array (
0 => 'bar',
)
Après changement : array (
0 => 'bar',
)
Tel que passé : array (
0 => 'bar',
)
Après changement : array (
0 => 'baz',
)

Notes

Note:

Parce que cette fonction dépend de la portée courante pour déterminer les détails des paramètres, ils ne peuvent être utilisés en tant que paramètre d'une fonction dans les versions antérieures à 5.3.0. Si vous devez passer cette valeur, assignez les résultats à une variable et utilisez-la.

Note:

Si les arguments sont passés par référence, toutes leurs modifications seront reflétées dans les valeurs retournées par cette fonction.

Note: Cette fonction retourne uniquement une copie des arguments passés, et ne compte ne traite pas les arguments par défaut (non passés).

Voir aussi

LoadingChargement en cours