PHP:从父方法中的静态方法调用子构造函数

时间:2010-08-02 20:37:52

标签: php static constructor subclass

我希望在父类中有一个静态方法,它创建我调用此方法的子类的实例。

使这一点更加清晰的一个例子:

class parent {
    public static method make_objects($conditions){
        for (...){
            // here i want to create an instance
            // of whatever subclass i am calling make_objects on
            // based on certain $conditions
        }
    }
}

class sub extends parent{
    ...
}

$objects = sub::make_objects($some_conditions);

4 个答案:

答案 0 :(得分:10)

从php 5.3开始,您可以使用static关键字

<?php
class A {
  public static function newInstance() {
    $rv = new static();  
    return $rv;
  }
}
class B extends A { }
class C extends B { }

$o = A::newInstance(); var_dump($o);
$o = B::newInstance(); var_dump($o);
$o = C::newInstance(); var_dump($o);

打印

object(A)#1 (0) {
}
object(B)#2 (0) {
}
object(C)#1 (0) {
}

编辑:另一个(类似)示例

<?php
class A {
  public static function newInstance() {
    $rv = new static();  
    return $rv;
  }

  public function __construct() { echo " A::__construct\n"; }
}
class B extends A {
  public function __construct() { echo " B::__construct\n"; }
}
class C extends B {
  public function __construct() { echo " C::__construct\n"; }   
}

$types = array('A', 'B', 'C');
foreach( $types as $t ) {
  echo 't=', $t, "\n";
  $o = $t::newInstance();
  echo '  type of o=', get_class($o), "\n";
}

打印

t=A
 A::__construct
  type of o=A
t=B
 B::__construct
  type of o=B
t=C
 C::__construct
  type of o=C

答案 1 :(得分:1)

我想你想要这样的东西:

class parent {
  public static function make_object($conditionns) {
    if($conditions == "case1") {
      return new sub();
    }
  }
}

class sub extends parent {

}

现在您可以创建一个这样的实例:

$instance = parent::make_object("case1");

$instance = sub::make_object("case1");

但是为什么你想要所有子类扩展父类?你不应该更喜欢你的模型(子类)和工厂类的父级,它根据给定的条件为这个模型创建实例吗?

答案 2 :(得分:0)

嗯,不会那样:

class sub extends parent {
  public static function make_objects($conditions) {
    //sub specific stuff here
    //....
  }
}

答案 3 :(得分:-1)

使父类成为一个抽象类,并使父方法也成为一个抽象的

abstract static class parent {
     abstract function make_method() {
         // your process
     }
}

class child extends parent {
     public function __construct() {
          parent::make_method();
     }
}