PHP Conference Japan 2024

ReflectionParameter 类

(PHP 5、PHP 7、PHP 8)

简介

ReflectionParameter 类检索有关函数或方法参数的信息。

要内省函数参数,首先创建 ReflectionFunctionReflectionMethod 类的实例,然后使用它们的 ReflectionFunctionAbstract::getParameters() 方法检索参数数组。

类概要

class ReflectionParameter implements Reflector {
/* 属性 */
public string $name;
/* 方法 */
public __construct(string|array|object $function, int|string $param)
public allowsNull(): bool
private __clone(): void
public static export(string $function, string $parameter, bool $return = ?): string
public getAttributes(?string $name = null, int $flags = 0): array
public getName(): string
public getPosition(): int
public hasType(): bool
public isOptional(): bool
public isPromoted(): bool
public isVariadic(): bool
public __toString(): string
}

属性

name

参数的名称。只读,尝试写入时会抛出 ReflectionException

变更日志

版本 描述
8.0.0 ReflectionParameter::export() 已移除。

目录

添加注释

用户贡献的注释 4 条注释

7
fgm at riff dot org
16 年前
关于 ReflectionParameter 构造函数签名的注释实际上是不完整的,至少在 5.2.5 中是这样:可以使用整数作为第二个参数,构造函数将使用它来返回第 n 个参数。

这允许您即使在记录来自扩展的代码时也能获得正确的 ReflectionParameter 对象,这些扩展(奇怪的是)定义了几个具有相同名称的参数。基于字符串的构造函数始终返回具有匹配名称的第一个参数,而基于整数的构造函数则正确返回第 n 个参数。

因此,简而言之,这有效
<?php
// 假设扩展定义了类似的内容:
// Some_Class::someMethod($a, $x, $y, $x, $y)
$p = new ReflectionParameter(array('Some_Class', 'someMethod'), 4);
// 返回最后一个参数,而
$p = new ReflectionParameter(array('Some_Class', 'someMethod'), 'y');
// 始终返回位置 2 处的第一个 $y
?>
3
killgecNOFSPAM at gmail dot com
17 年前
ReflectionParameter 构造函数的签名正确的是

public function __construct(array/string $function, string $name);

其中 $function 是全局函数的名称,或者类/方法名称对。
1
massimo at mmware dot it
17 年前
我发现使用来自 ReflectionFunction 的 ReflectionParameter 类对内部函数(例如 print_r、str_replace 等)存在这些限制

1. 参数名称与手册不匹配:(尝试使用 arg“call_user_func”的示例 19.35)
2. 一些函数(例如 PCRE 函数,preg_match 等)具有空参数名称
3. 对参数调用 getDefaultValue 将导致异常“无法确定内部函数的默认值”
0
rasmus at mindplay dot dk
1 年前
现在有这么多种参数模式,我需要准确地知道 `ReflectionParameter` 将返回什么,所以我编写了一个小测试脚本 - 您可以在此处找到该脚本和结果表

https://gist.github.com/mindplay-dk/082458088988e32256a827f9b7491e17
To Top