萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> php編程 >> php接口和抽象類使用示例詳解

php接口和抽象類使用示例詳解

 這篇文章主要介紹了php的接口和抽象類使用示例,並做了詳解講解,需要的朋友可以參考下

一、 抽象類abstract class   1 .抽象類是指在 class 前加了 abstract 關鍵字且存在抽象方法(在類方法 function 關鍵字前加了 abstract 關鍵字)的類。   2 .抽象類不能被直接實例化。抽象類中只定義(或部分實現)子類需要的方法。子類可以通過繼承抽象類並通過實現抽象類中的所有抽象方法,使抽象類具體化。   3 .如果子類需要實例化,前提是它實現了抽象類中的所有抽象方法。如果子類沒有全部實現抽象類中的所有抽象方法,那麼該子類也是一個抽象類,必須在 class 前面加上 abstract 關鍵字,並且不能被實例化。    代碼如下: abstract class A   {       /** 抽象類中可以定義變量 */      protected $value1 = 0;       private $value2 = 1;       public $value3 = 2;       /** 也可以定義非抽象方法 */      public function my_print()       {           echo "hello,world/n";       }       /**       * 大多數情況下,抽象類至少含有一個抽象方法。抽象方法用abstract關鍵字聲明,其中不能有具體內容。       * 可以像聲明普通類方法那樣聲明抽象方法,但是要以分號而不是方法體結束。也就是說抽象方法在抽象類中不能被實現,也就是沒有函數體“{some codes}”。       */      abstract protected function abstract_func1();       abstract protected function abstract_func2();   }   abstract class B extends A   {       public function abstract_func1()       {          echo "implement the abstract_func1 in class A/n";       }       /** 這麼寫在zend studio 8中會報錯*/      //abstract protected function abstract_func2();   }   class C extends B   {       public function abstract_func2()       {          echo "implement the abstract_func2 in class A/n";       }   }       4 .如果像下面這樣創建了一個繼承自 A 的子類 B ,但是不實現抽象方法 abstract_func() :  代碼如下: Class B extends A{};       那麼程序將出現以下錯誤:     代碼如下:  Fatal error: Class B contains 1 abstract method and must therefore be declared abstract or implement the remaining methods (A::abstract_func)      5 .如果 B 實現了抽象方法 abstract_func() ,那麼 B 中 abstract_func() 方法的訪問控制不能比 A 中 abstract_func() 的訪問控制更嚴格,也就是說:   (1)      如果 A 中 abstract_func() 聲明為 public ,那麼 B 中 abstract_func() 的聲明只能是 public ,不能是 protected 或 private   (2)      如果 A 中 abstract_func() 聲明為 protected ,那麼 B 中 abstract_func() 的聲明可以是 public 或 protected ,但不能是 private   (3)      如果 A 中 abstract_func() 聲明為 private ,嘿嘿,不能定義為 private 哦!( Fatal error : Abstract function A::abstract_func() cannot be declared private )   二、 接口interface   1 .抽象類提供了具體實現的標准,而接口則是純粹的模版。接口只定義功能,而不包含實現的內容。接口用關鍵字 interface 來聲明。   2 . interface 是完全抽象的,只能聲明方法,而且只能聲明 public 的方法,不能聲明 private 及 protected 的方法,不能定義方法體,也不能聲明實例變量 。然而, interface 卻可以聲明常量變量 。但將常量變量放在 interface 中違背了其作為接口的作用而存在的宗旨,也混淆了 interface 與類的不同價值。如果的確需要,可以將其放在相應的 abstract class 或 Class 中。    代碼如下: interface iA   {       const AVAR=3;       public function iAfunc1();       public function iAfunc2();   }   echo iA:: AVAR;      3 .任何實現接口的類都要實現接口中所定義的所有方法   代碼如下: class E implements iA   {       public function iAfunc1(){echo "in iAfunc1";}       public function iAfunc2(){echo "in iAfunc2";}   }       否則該類必須聲明為 abstract 。     復制代碼 代碼如下: abstract class E implements iA{}       4 .一個類可以在聲明中使用 implements 關鍵字來實現某個接口。這麼做之後,實現接口的具體過程和繼承一個僅包含抽象方法的抽象類是一樣的。一個類可以同時繼承一個父類和實現任意多個接口。 extends 子句應該在 implements 子句之前。 PHP 只支持繼承自一個父類,因此 extends 關鍵字後只能跟一個類名。    代碼如下: interface iB   {       public function iBfunc1();       public function iBfunc2();   }   class D extends A implements iA,iB   {       public function abstract_func1()       {          echo "implement the abstract_func1 in class A/n";       }       public function abstract_func2()       {          echo "implement the abstract_func2 in class A/n";       }       public function iAfunc1(){echo "in iAfunc1";}       public function iAfunc2(){echo "in iAfunc2";}       public function iBfunc1(){echo "in iBfunc1";}       public function iBfunc2(){echo "in iBfunc2";}   }     class D extends B implements iA,iB   {       public function abstract_func1()       {          parent::abstract_func1();          echo "override the abstract_func1 in class A/n";       }       public function abstract_func2()       {          echo "implement the abstract_func2 in class A/n";       }       public function iAfunc1(){echo "in iAfunc1";}       public function iAfunc2(){echo "in iAfunc2";}       public function iBfunc1(){echo "in iBfunc1";}       public function iBfunc2(){echo "in iBfunc2";}   }       5 .接口不可以實現另一個接口,但可以繼承多個  代碼如下: interface iC extends iA,iB{}   class F implements iC   {       public function iAfunc1(){echo "in iAfunc1";}       public function iAfunc2(){echo "in iAfunc2";}       public function iBfunc1(){echo "in iBfunc1";}       public function iBfunc2(){echo "in iBfunc2";}   }       三、 抽象類和接口的異同   1. 相同點:   (1)      兩者都是抽象類,都不能實例化。   (2)      interface 實現類及 abstract class 的子類都必須要實現已經聲明的抽象方法。   2. 不同點:   (1)      interface 需要實現,要用 implements ,而 abstract class 需要繼承,要用 extends 。   (2)      一個類可以實現多個 interface ,但一個類只能繼承一個 abstract class 。   (3)      interface 強調特定功能的實現,而 abstract class 強調所屬關系。   (4)      盡管 interface 實現類及 abstract class 的子類都必須要實現相應的抽象方法,但實現的形式不同。 interface 中的每一個方法都是抽象方法,都只是聲明的 (declaration, 沒有方法體 ) ,實現類必須要實現。而 abstract class 的子類可以有選擇地實現。這個選擇有兩點含義: a) abstract class 中並非所有的方法都是抽象的,只有那些冠有 abstract 的方法才是抽象的,子類必須實現。那些沒有 abstract 的方法,在 abstract class 中必須定義方法體; b) abstract class 的子類在繼承它時,對非抽象方法既可以直接繼承,
copyright © 萬盛學電腦網 all rights reserved