0

new self()使用当前实例的构造函数的正确方法是什么?换句话说,当我这样做时:

class Foo{
  function create(){
    return new self();
  }
}

Class Bar extends Foo{
}

$b = new Bar();
echo get_class($b->create());

我想看到:Bar而不是:Foo

4

3 回答 3

2
class Foo{
  function create(){
    $c = get_class($this);
    return new $c();
  }
}

Class Bar extends Foo{
}

$b = new Bar();
echo get_class($b->create());

将类类型存储在临时变量中,然后返回它的新实例。

于 2013-04-12T05:31:23.680 回答
1
public static function create()
{
    $class = get_called_class();

    return new $class();
}

这应该有效。

class Foo{
  public static function create()
    {
        $class = get_called_class();

        return new $class();
    }
}

class Bar extends Foo{
}

$a = Foo::create();
$b = Bar::create();

echo get_class($a), PHP_EOL, get_class($b);

显示:

Foo Bar

升级版:

如果你想要非静态,那么:

<?php
class Foo{
  public function create()
    {
        $class = get_class($this);

        return new $class();
    }
}

class Bar extends Foo{}

$a = new Bar();
$b = $a->create();

echo get_class($a), PHP_EOL, get_class($b);
?>

显示:

Bar Bar
于 2013-04-12T05:14:26.003 回答
0
Class Bar extends Foo {
function create(){
return self;
}}

如果你从子类调用一个函数,那么它是否会搜索最近的父类来调用它。这是继承。

这个想法是在这种情况下使用多态性。从子级重新声明一个函数会覆盖它的父级活动。如果你也想运行它的父函数,那么你必须像这样调用它parent::callee();

于 2013-04-12T05:16:59.413 回答