ReflectionClass::newInstance

(PHP 5, PHP 7, PHP 8)

ReflectionClass::newInstance从指定的参数创建一个新的类实例

说明

public ReflectionClass::newInstance(mixed $args, mixed $... = ?): object

创建类的新的实例。给出的参数将会传递到类的构造函数。

参数

args

接受可变数目的参数,用于传递到类的构造函数,和 call_user_func() 很相似。

返回值

错误/异常

如果类的构造函数不是 public 的将会导致一个 ReflectionException

args 指定了一个或多个参数,而类不具有构造函数时,将导致一个 ReflectionException

参见

add a note add a note

User Contributed Notes 2 notes

up
0
feryardiant at pm dot me
2 years ago
I don't know why it's not documented anywhere, when you (accidentally) pass an abstract class name you'll get the instance of Error class instead of ReflectionException class.

<?php
function reflect(string $class) {
    try {
        (new
ReflectionClass($class))->newInstance();
    } catch (
Throwable $e) {
        echo
get_class($e) . ' : ' . $e->getMessage() . PHP_EOL;
    }
}

abstract class
A {}

class
B {
    private function
__construct() {}
}

reflect(A::class); // => Error : Cannot instantiate abstract class A
reflect(B::class); // => ReflectionException : Access to non-public constructor of class B
up
-5
glen at delfi dot ee
8 years ago
looks like reflection class newInstance creates in memory representation of code where values are used, so using reference as constructor signature, you can not use this method.

as  the same input if called via new, or new $class works, but not via reflection:

class a {
     public function __construct(&$a, $c) {
     }
}

// this works
$A = new stdClass();
$a = new a($A, 11);

// also this works
$classname = "a";
$a = new $classname($A, 10);

// but this fails:
$r = new ReflectionClass("a");
$r->newInstance($A, 10);

PHP Warning:  Parameter 1 to a::__construct() expected to be a reference, value given in reflection.php on line 15

PHP Warning:  ReflectionClass::newInstance(): Invocation of a's constructor failed in reflection.php on line 15
To Top