5

我正在尝试创建一个这样的类的新实例:

$obj = new $class;

我这样做的方式是一组通用函数将为许多类执行此操作,但现在我正在实现一些参数。现在虽然处理函数看起来像这样:

function newInst($argA = null, $argB = null, $argC = null)

这必须事先包含所有参数,并且有一个上限。所以,我正在尝试做这样的事情:

function newInst() {
    $obj = new $class(func_get_args());
    ...
}

但不是只应用第一个参数,我希望它将数组作为一组参数应用。我试过了

function newInst() {
    $obj = new $class;
    call_user_func_array(array($obj, '__construct'), func_get_args());
    ...
}

但这会调用该__construct函数两次。那么,有没有办法使用被调用函数的参数来创建一个新实例,该实例将在实例化期间通过__constructorclassname函数?

4

1 回答 1

6

如果您不反对使用反射:ReflectionClass::newInstanceArgs

function createInstance($class, array $arguments) {
    $reflection = new ReflectionClass($class);
    return $reflection->newInstanceArgs($arguments);
}

反射提供了很多东西,尽管人们普遍认为它“”,但反射很少会成为应用程序中的真正瓶颈。无论如何,缓存都可以减轻任何可能性。


基于讨论,我只是用count()检查和幼稚缓存来修改一个假设的解决方案;它仍然(肯定)需要分析。

function createInstance($class, array $arguments) {
    static $cache = [];
    switch (count($arguments)) {
        case 0: return new $class();
        case 1: return new $class($arguments[0]);
        case 2: return new $class($arguments[0], $arguments[1]);
        case 3: return new $class($arguments[0], $arguments[1], $arguments[2]);
    }
    if (!isset($cache[$class])) {
        $cache[$class] = new ReflectionClass($class);
    }
    return $cache[$class]->newInstanceArgs($arguments);
}    
于 2013-06-25T12:44:24.923 回答