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
