func_get_arg 返回参数列表的某一项

发表日期:2021-07-01 08:57:15 | 来源: | | 浏览(761) 分类:函数处理 函数

func_get_arg

(PHP 4, PHP 5, PHP 7, PHP 8)

func_get_arg返回参数列表的某一项

说明

func_get_arg(int $arg_num): mixed

从用户自定义函数的参数列表中获取某个指定的参数。

该函数可以配合 func_get_args()func_num_args() 一起使用,从而使得用户自定义函数可以接受自定义个数的参数列表。

参数

arg_num

参数的偏移量。函数的参数是从0开始计数的。

返回值

返回指定的参数,错误则返回 false

更新日志

版本 说明
5.3.0 该函数可以在参数列表中使用。
5.3.0 If this function is called from the outermost scope of a file which has been included by calling include or require from within a function in the calling file, it now generates a warning and returns false. (不知道如何翻译跟好,直接参考例2即可明白)

错误/异常

当在自定义函数的外面调用的该函数的时候会发出一个警告, 或者是当 arg_num 比实际传入的参数的数目大的时候也会发出一个警告。

范例

示例 #1 func_get_arg() 例子

<?php 
function foo(){
     $numargs = func_num_args();
     echo "Number of arguments: $numargs<br />\n";
     if ($numargs >= 2) {
         echo "Second argument is: " . func_get_arg(1) . "<br />\n";
     }
}
foo (1, 2, 3);
?>

示例 #2 func_get_arg() PHP 5.3 前后对比的例子

test.php<?php 
function foo() {
    include './fga.inc';
}
foo('First arg', 'Second arg');
?>fga.inc<?php$arg = func_get_arg(1);
var_export($arg);
?>

PHP 5.3 版本之前的输出:

'Second arg'

PHP 5.3 和之后的版本的输出:

Warning: func_get_arg():  Called from the global scope - no function
context in /home/torben/Desktop/code/ml/fga.inc on line 3
false

示例 #3 func_get_arg() example of byref and byval arguments

<?php 
function byVal($arg) {
    echo 'As passed     : ', var_export(func_get_arg(0)), PHP_EOL;
    $arg = 'baz';
    echo 'After change  : ', var_export(func_get_arg(0)), PHP_EOL;
}
function byRef(&$arg) {
    echo 'As passed     : ', var_export(func_get_arg(0)), PHP_EOL;
    $arg = 'baz';
    echo 'After change  : ', var_export(func_get_arg(0)), PHP_EOL;
}
$arg = 'bar';
byVal($arg);
byRef($arg);
?>

以上例程会输出:


As passed : 'bar'
After change : 'bar'
As passed : 'bar'
After change : 'baz'

注释

注意:

因为函数依赖于当前作用域以确定参数的细节,所以在 5.3.0 以前的版本中不能用作函数的参数。如必须传递此值时,可将结果赋与一个变量,然后用此变量进行传递。

注意:

如果参数以引用方式传递,函数对该参数的任何改变将在函数返回后保留。As of PHP 7 the current values will also be returned if the arguments are passed by value.

注意: This function returns a copy of the passed arguments only, and does not account for default (non-passed) arguments.

参见

集速网 copyRight © 2015-2022 宁ICP备15000399号-1 宁公网安备 64010402001209号
与其临渊羡鱼,不如退而结网
欢迎转载、分享、引用、推荐、收藏。