抽象類別的特性
#1、定義為抽象的類別不能被實例化。
2、如果它裡面至少有一個方法是被宣告為抽象的,那麼這個類別就必須被宣告為抽象的。
3、被定義為抽象的方法只是宣告了其呼叫方式(參數),不能定義其特定的功能實作。
4、繼承一個抽象類別的時候,子類別必須定義父類別中的所有抽象方法(這些方法的存取控制必須和父類別中一樣(或更為寬鬆)。)
demo
abstract class AbstractClass{ // 强制要求子类定义这些方法 abstract protected function getValue(); abstract protected function prefixValue($prefix); // 普通方法(非抽象方法) public function printOut() { print $this->getValue() . "\n"; } class ConcreteClass1 extends AbstractClass{ //父类定义了俩个抽象方法,如子类只实现了其中一个,则报如下错误//Fatal error: Class ConcreteClass1 contains 1 abstract //method and must therefore be declared abstract or //implement the remaining methods //(AbstractClass::prefixValue) protected function getValue() { return "ConcreteClass1"; } // 且子类的访问权限不能低于父类,如果将如下子类的访问方式改为private则会报如下错误 //Fatal error: Access level to //ConcreteClass1::prefixValue() must be protected (as in //class AbstractClass) or weaker public function prefixValue($prefix) { return "{$prefix}ConcreteClass1"; } } //当实例化一个抽象类时,Fatal error: Cannot instantiate //abstract class AbstractClass //$obj = new AbstractClass(); // 但是我们可以这么使用########################################################## abstract class Foo{ static function bar() { echo "test\n"; } } Foo::bar();########################################################## $obj = new ConcreteClass1(); echo $obj->getValue();
5、子類別可以定義一個可選參數(也就是必須要有預設值),而父類別抽象方法的宣告裡沒有,則兩者的聲明並無衝突。
abstract class AbstractClass{ // 我们的抽象方法仅需要定义需要的参数 abstract protected function prefixName($name); } class ConcreteClass extends AbstractClass { // 我们的子类可以定义父类签名中不存在的可选参数 // 如果这里的$separator没有默认值,则会报Fatal error: 、、//Declaration of ConcreteClass::prefixName() must be //compatible with that of AbstractClass::prefixName() 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"), "\n"; echo $class->prefixName("Pacwoman"), "\n";
6、抽象類別可以沒有抽象方法,反過來有抽象方法的類別一定要宣告為抽象類別
abstract class A{ public function show(){ echo 'A'; } } class B extends A{ public function hello(){ echo 'B'; parent::show(); } } $obj = new B; $obj->hello(); // BA
7、抽象類別定義的順序
// 正确的定义顺序 abstract class horse extends animal { public function get_breed() { return "Jersey"; } } class cart extends horse { public function get_breed() { return "Wood"; } } // 错误的定义顺序,将会导致horse类找不到 class cart extends horse { public function get_breed() { return "Wood"; } } abstract class horse extends animal { public function get_breed() { return "Jersey"; } }
8.抽象方法可以為靜態方法
abstract class FOO { abstract static function dump(); } class BAR extends FOO{ static function dump(){var_dump("BAR");} } BAR::dump(); // string(3) "BAR"
9、一個抽象類別繼承另一個抽象類別時,抽象方法不需要宣告為抽象的
//Fatal error: Can't inherit abstract function //class1::someFunc() (previously declared abstract in //class2)abstract class class1 { abstract public function someFunc(); } abstract class class2 extends class1 { abstract public function someFunc(); } //下面的是正确的 abstract class class1 { abstract public function someFunc(); } abstract class class2 extends class1 { }
以上是php抽象類別特性實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!