PHP 5 支持抽象类和抽象方法。定义为抽象的类不能被实例化。任何一个类,如果它里面至少有一个方法是被声明为抽象的,那么这个类就必须被声明为抽象的。被定义为抽象的方法只是声明了其调用方式(参数),不能定义其具体的功能实现。
继承一个抽象类的时候,子类必须定义父类中的所有抽象方法;另外,这些方法的访问控制必须和父类中一样(或者更为宽松)。例如某个抽象方法被声明为受保护的,那么子类中实现的方法就应该声明为受保护的或者公有的,而不能定义为私有的。此外方法的调用方式必须匹配,即类型和所需参数数量必须一致。例如,子类定义了一个可选参数,而父类抽象方法的声明里没有,则两者的声明并无冲突。 这也适用于 PHP 5.4 起的构造函数。在 PHP 5.4 之前的构造函数声明可以是不一样的。
Example #1 抽象类示例
abstract class AbstractClass { //强制要求子类定义这些方法 abstract protected function getValue(); abstract protected function prefixValue($prefix); //普通方法(非抽象方法) public function printOut() { print $this->getValue().'<br>'; } } class ConcreteClass1 extends AbstractClass { protected function getValue() { return "ConcteteClass1"; } public function prefixValue($prefix){ return "{$prefix}ConcreteClass1"; } } class ConcreteClass2 extends AbstractClass { public function getValue(){ return "ConcreteClass2"; } public function prefixValue($prefix){ return "{$prefix}ConcreteClass2"; } } $class1 = new ConcreteClass1; $class1 -> printOut(); echo $class1->prefixValue('Foo_')."<br>"; $class2 = new ConcreteClass2; $class2 -> printOut(); echo $class2->prefixValue('Bar_')."<br>";
输出结果:
ConcteteClass1
Foo_ConcreteClass1
ConcreteClass2
Bar_ConcreteClass2
Example #2 抽象类示例
abstract class AbstractClass { //我们的抽象方法仅需要定义需要的参数 abstract protected function prefixName($name); } class ConcreteClass extends AbstractClass { //我们的子类可以定义父类签名中不存在的可选参数 public function prefixName($name,$separator='.'){ if($name == 'Pacman'){ $prefix = "Mr"; }elseif($name == 'Pacwoman'){ $prefix = 'Mrs'; }else{ $prefix = ""; } return "{$prefix}{$separator} {$name}"; } } $class = new ConcreteClass; echo $class->prefixName('Pacman').'<br>'; echo $class->prefixName('Pacwoman').'<br>';
输出结果:
Mr. Pacman
Mrs. Pacwoman