1. 抽象クラス
1.抽象クラスとは、クラスと抽象メソッド(クラスメソッドの関数キーワードの前に抽象キーワード)の前に抽象キーワードを追加したクラスを指します。 2.抽象クラスは直接インスタンス化できません。抽象クラスは、サブクラスに必要なメソッドのみを定義 (または部分的に実装) します。サブクラスは、抽象クラスを継承し、抽象クラス内のすべての抽象メソッドを実装することによって、抽象クラスを具体化できます。 3.サブクラスをインスタンス化する必要がある場合は、抽象クラス内のすべての抽象メソッドを実装する必要があります。サブクラスが抽象クラス内のすべての抽象メソッドを実装していない場合、そのサブクラスも抽象クラスであり、クラス内でその前に 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"; } }
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)
アクセス制御 は、A の abstract_func() のアクセス制御よりも厳密にすることはできません。つまり、
(1) If abstract_func A の () public として宣言されている場合、B の abstract_func() の宣言は public のみにすることができ、protected または private にすることはできません(2) A の abstract_func() が protected として宣言されている場合、abstract_func() の宣言はB では public または protected にすることができますが、private にすることはできません(3) A の abstract_func() が private として宣言されている場合、へー、private として定義することはできません。 (致命的なエラー: 抽象関数 A::abstract_func() はプライベートとして宣言できません)2. 1.抽象クラスは具体的な実装の標準を提供しますが、インターフェイスは純粋なテンプレートです。インターフェイスは関数のみを定義し、実装内容は定義しません。インターフェースはキーワードinterfaceで宣言されます。 2.インターフェイスは完全に抽象的であり、メソッドとパブリック メソッドのみを宣言でき、メソッド本体を定義できず、インスタンス変数も宣言できません。ただし、インターフェイスでは定数変数を宣言できます。しかし、インターフェイスに定数変数を配置すると、インターフェイスとして存在する目的に違反し、インターフェイスとクラスのさまざまな値が混乱します。本当に必要な場合は、対応する抽象クラスまたはクラスに配置できます。コードは次のとおりです:
interface iA { const AVAR=3; public function iAfunc1(); public function iAfunc2(); } echo iA:: AVAR;
class E implements iA { public function iAfunc1(){echo "in iAfunc1";} public function iAfunc2(){echo "in iAfunc2";} }
コードは次のとおりです:
abstract class E implements iA{}
コードは次のとおりです:
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";} }
コードは次のとおりです:
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";} }
(4) インターフェース実装クラスも抽象クラスのサブクラスも対応する抽象メソッドを実装する必要がありますが、実装形式が異なります。インターフェイス内のすべてのメソッドは抽象メソッドであり、宣言のみであり (宣言、メソッド本体はありません)、実装クラスはそれを実装する必要があります。抽象クラスのサブクラスは選択的に実装できます。この選択には次の 2 つの意味があります。 a) 抽象クラス内のすべてのメソッドが抽象であるわけではなく、抽象を持つメソッドだけが抽象であり、サブクラスはそれらを実装する必要があります。抽象を持たないメソッドの場合は、メソッド本体を抽象クラスで定義する必要があります。b) 抽象クラスのサブクラスがそれを継承する場合、非抽象メソッドを直接継承またはオーバーライドできます。また、抽象メソッドの場合は、実装するかオーバーライドするかを選択できます。実装はそのサブクラスに任せることができますが、このクラスも抽象として宣言する必要があります。抽象クラスなので当然インスタンス化できません。
(5) 抽象クラスはインターフェイスとクラスの間の仲介者です。抽象クラスはインターフェイスとクラスを接続する役割を果たします。一方では、抽象クラスは抽象的であり、サブクラスが実装する必要がある関数を標準化するために抽象メソッドを宣言できます。他方では、サブクラスによって直接使用またはオーバーライドされるデフォルトのメソッド本体を定義できます。さらに、継承を通じてサブクラスで使用する独自のインスタンス変数を定義できます。
(6) インターフェース内の抽象メソッドの前に抽象キーワードを追加することはできません。抽象メソッドはデフォルトで暗黙的であり、抽象メソッドの継承を防ぐためにfinalキーワードを追加することはできません。抽象クラスの抽象メソッドは、抽象メソッドとして明示的に宣言されていることを示すために、その前に abstract を付ける必要があります。
(7) インターフェイスの抽象メソッドはデフォルトでパブリックであり、プライベート修飾子または保護された修飾子を使用してのみ変更できます。抽象クラスの抽象メソッドは、public および protected で変更できますが、private で変更することはできません。
3. インターフェースの応用シナリオ
(1) クラスは、実装方法に関係なく、調整のために特定のインターフェースを必要とします。
(2) 特定の機能を実装できる識別子として存在することも、インターフェイス メソッドを持たない純粋な識別子であることもできます。
(3) クラスのグループを単一のクラスとして扱う必要があり、呼び出し元はインターフェイスを通じてこのクラスのグループにのみ連絡します。
(4) 複数の特定の機能を実装する必要があり、それらの機能はまったく関連していない可能性があります。
4. 抽象クラスの適用場面
つまり、統一されたインターフェースとインスタンス変数またはデフォルトメソッドの両方が必要な場合に使用できます。最も一般的なものは次のとおりです:
(1) インターフェイスのセットを定義しますが、各実装クラスにすべてのインターフェイスの実装を強制したくありません。抽象クラスを使用してメソッド本体のセット、または空のメソッド本体を定義すると、サブクラスが対象となるメソッドを選択できます。
(2) 場合によっては、純粋なインターフェイスだけではクラス間の調整を満たすことができず、異なる関係を区別するためにクラス内の状態を表す変数も必要になります。アブストラクトの仲介的な役割はこれに役立ちます。
(3) 相互に調整されたメソッドのセットを標準化します。その一部は共通で状態に依存せず、サブクラスが個別に実装する必要なく共有できますが、他のメソッドは各サブクラスが独自のメソッドに従って実装する必要があります。特定の機能を実装するには特定の状態。
以上がphpインターフェースと抽象クラスの使用例コードの詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。