ReflectionMethod 类

(PHP 5, PHP 7, PHP 8)

简介

ReflectionMethod 类报告有关方法的信息。

类概要

class ReflectionMethod extends ReflectionFunctionAbstract {
/* 常量 */
public const int IS_STATIC;
public const int IS_PUBLIC;
public const int IS_PROTECTED;
public const int IS_PRIVATE;
public const int IS_ABSTRACT;
public const int IS_FINAL;
/* 属性 */
public string $class;
/* 继承的属性 */
public string $name;
/* 方法 */
public __construct(object|string $objectOrMethod, string $method)
public __construct(string $classMethod)
public static createFromMethodName(string $method): static
public static export(string $class, string $name, bool $return = false): string
public getClosure(?object $object = null): Closure
public getModifiers(): int
public hasPrototype(): bool
public invoke(?object $object, mixed ...$args): mixed
public invokeArgs(?object $object, array $args): mixed
public isAbstract(): bool
public isDestructor(): bool
public isFinal(): bool
public isPrivate(): bool
public isProtected(): bool
public isPublic(): bool
public setAccessible(bool $accessible): void
public __toString(): string
/* 继承的方法 */
}

属性

name

方法名称

class

类名

预定义常量

ReflectionMethod 修饰符

ReflectionMethod::IS_STATIC

表示该方法是静态的。在 PHP 7.4.0 之前,其值为 1

ReflectionMethod::IS_PUBLIC

表示该方法是公共的。在 PHP 7.4.0 之前,其值为 256

ReflectionMethod::IS_PROTECTED

表示该方法是受保护的。在 PHP 7.4.0 之前,其值为 512

ReflectionMethod::IS_PRIVATE

表示该方法是私有的。在 PHP 7.4.0 之前,其值为 1024

ReflectionMethod::IS_ABSTRACT

表示该方法是抽象的。在 PHP 7.4.0 之前,其值为 2

ReflectionMethod::IS_FINAL

表示该方法是最终的。在 PHP 7.4.0 之前,其值为 4

注意:

这些常量的值在不同的 PHP 版本之间可能会有所不同。建议始终使用常量,不要直接依赖值。

变更日志

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

目录

添加笔记

用户贡献笔记 3 笔记

9
匿名
3 年前
当类的构造函数依赖于其他类(带类型提示)时,我们可以为类创建“自动依赖注入”。

<?php

class Dependence1 {
function
foo() {
echo
"foo";
}
}

class
Dependence2 {
function
foo2() {
echo
"foo2";
}
}

final class
myClass
{
private
$dep1;
private
$dep2;

public function
__construct(
Dependence1 $dependence1,
Dependence2 $dependence2
)
{
$this->dep1 = $dependence1;
$this->dep2 = $dependence2;
}

}

// 自动依赖注入(类)

$constructor = new ReflectionMethod(myClass::class, '__construct');
$parameters = $constructor->getParameters();

$dependences = [];
foreach (
$parameters as $parameter) {
$dependenceClass = (string) $parameter->getType();
$dependences[] = new $dependenceClass();
}

$instance = new myClass(...$dependences);
var_dump($instance);

?>

结果是

object(myClass)#6 (2) {
["dep1":"myClass":private]=>
object(Dependence1)#4 (0) {
}
["dep2":"myClass":private]=>
object(Dependence2)#5 (0) {
}
}
12
webseiten dot designer at googlemail dot com
13 年前
请注意,公共成员 $class 包含定义方法的类的名称。

<?php
class A {public function __construct() {}}
class
B extends A {}

$method = new ReflectionMethod('B', '__construct');
echo
$method->class; // 打印 'A'
?>
-19
no dot prob at gmx dot net
18 年前
我编写了一个函数,它返回给定 DocComment 标签的值。

完整示例

<?php

header
('Content-Type: text/plain');

class
Example
{
/**
* 这是我的 DocComment!
*
* @DocTag: 打印 Hello World!
*/
public function myMethod()
{
echo
'Hello World!';
}
}

function
getDocComment($str, $tag = '')
{
if (empty(
$tag))
{
return
$str;
}

$matches = array();
preg_match("/".$tag.":(.*)(\\r\\n|\\r|\\n)/U", $str, $matches);

if (isset(
$matches[1]))
{
return
trim($matches[1]);
}

return
'';
}

$method = new ReflectionMethod('Example', 'myMethod');

// 将返回 Hello World!
echo getDocComment($method->getDocComment(), '@DocTag');

?>

也许您可以将此功能添加到反射类的 getDocComment 方法中。
To Top