<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ??碼云GVP開源項目 12k star Uniapp+ElementUI 功能強大 支持多語言、二開方便! 廣告
                PHP與大多數面向對象編程語言一樣,不支持多重繼承。也就是說每個類只能繼承一個父類。為了解決這個問題,PHP引入了接口,接口的思想是指定了一個實現了該接口的類必須實現的一系列方法。接口是一種特殊的抽象類,抽象類又是一種特殊的類,所以接口也是一種特殊的類,為 什么說接口是一種特殊的抽象類呢?如果一個抽象類里面的所有的方法都是抽象方法,那么我們就換一種聲明方法使用“接口”;也就是說接口里面所有的方法必須 都是聲明為抽象方法,另外接口里面不能聲明變量(但可聲明常量constant),而且接口里面所有的成員都是public權限的。所以子類在實現的時候 也一定要使用public權限實限。 聲明一個類的時候我們使用的關鍵字是“class”,而接口一種特殊的類,使用的關鍵字是“interface”; 類的定義: class 類名{ … } , 接口的聲明:interface 接口名{ …} ~~~ 1 <?php 2 //定義一個接口使用interface關鍵字,“One”為接口名稱 3 interface One 4 { 5 //定義一個常量 6 const constant = 'constant value'; 7 8 //定義了一個抽象方法”fun1” 9 public function fun1(); 10 11 //定義了抽象方法”fun2” 12 public function fun2(); 13 } 14 ?> ~~~ 上例中定義了一個接口“one”,里面聲明了兩個抽象方法“fun1”和”fun2”,因為接口里面所有的方法都是抽象方法,所以在聲明抽象方法的時候就不用像抽象類那樣使用“abstract”這個關鍵字了,默認的已經加上這個關鍵字,另外在接口里邊的”public”這個訪問權限也可以去掉,因 為默認就是public的,因為接口里所有成員都要是公有的,所在對于接口里面的成員我們就不能使用“private”的和“protected”的權限 了,都要用public或是默認的。另外在接口里面我們也聲明了一個常量“constant“, 因為在接口里面不能用變量成員,所以我們要使用 const這個關鍵字聲明。 因為接口是一種特殊的抽象類,里面所有的方法都是抽象方法,所以接口也不能產生實例對象; 它也做為一種規范,所有抽象方法需要子類去實現。 我們可以使用”extends”關鍵字讓一個接口去繼承另一個接口: ~~~ 1 <?php 2 //使用”extends”繼承另外一個接口 3 interface Two extends One 4 { 5 function fun3(); 6 function fun4(); 7 } 8 ?> ~~~ 而我們定義一接口的子類去實現接口中全部抽象方法使用的關鍵字是“implements”,而不是我們前面所說的“extends”; ~~~ 1 <?php 2 //使用“implements”這個關鍵字去實現接口中的抽象方法 接口和類之間 3 class Three implements One 4 { 5 function fun1() { 6 ... 7 } 8 9 function fun2() { 10 ... 11 } 12 } 13 14 //實現了全部方法,我們去可以使用子類去實例化對象了 15 $three=new Three(); 16 ?> ~~~ 我們也可以使用抽象類,去實現接口中的部分抽象方法,但要想實例化對象,這個抽象類還要有子類把它所有的抽象方法都實現才行; 在前面我們說過,PHP是單繼承的,一個類只能有一父類,但是一個類可以實現多個接口,就相當于一個類要遵守多個規范,就像我們不僅要遵守國家的法律,如果是在學校的話,還要遵守學校的校規一樣; ~~~ 1 <?php 2 //使用implements實現多個接口 3 class Four implemtns 接口一, 接口二, ... 4 { 5 //必須把所有接口中的方法都要實現才可以實例化對象。 6 } 7 ?> ~~~ PHP中不僅一個類可以實現多個接口,也可以在繼承一個類的同時實現多個接口, 一定要先繼承類再去實現接口; ~~~ 1 <?php 2 //使用extends繼承一個類,使用implements實現多個接口 3 class Four extends 類名一 implemtns 接口一, 接口二, ... 4 { 5 //所有接口中的方法都要實現才可以實例化對象 6 ... 7 } 8 ?> ~~~
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看