new self()
使用当前实例的构造函数的正确方法是什么?换句话说,当我这样做时:
class Foo{
function create(){
return new self();
}
}
Class Bar extends Foo{
}
$b = new Bar();
echo get_class($b->create());
我想看到:Bar
而不是:Foo
new self()
使用当前实例的构造函数的正确方法是什么?换句话说,当我这样做时:
class Foo{
function create(){
return new self();
}
}
Class Bar extends Foo{
}
$b = new Bar();
echo get_class($b->create());
我想看到:Bar
而不是:Foo
class Foo{
function create(){
$c = get_class($this);
return new $c();
}
}
Class Bar extends Foo{
}
$b = new Bar();
echo get_class($b->create());
将类类型存储在临时变量中,然后返回它的新实例。
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
Class Bar extends Foo {
function create(){
return self;
}}
如果你从子类调用一个函数,那么它是否会搜索最近的父类来调用它。这是继承。
这个想法是在这种情况下使用多态性。从子级重新声明一个函数会覆盖它的父级活动。如果你也想运行它的父函数,那么你必须像这样调用它parent::callee();