<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>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                [TOC] 接口是一種由程序員來定義的類型,一個接口類型就是一組方法的集合,它規定了需要實現的所有方法。 ## 接口定義 接口的定義格式 ```go type 接口類型名稱 interface { 方法名(形參1, ...) (返回值1, ...) ... } ``` >[info] **說明** > - 接口類型名稱:Go語言的接口在命名時,一般會在單詞后面添加er,如有寫操作的接口叫Writer,有關閉操作的接口叫closer等。接口名最好要能突出該接口的類型含義。 > - 方法名:當方法名首字母是大寫且這個接口類型名首字母也是大寫時,這個方法可以被接口所在的包(package)之外的代碼訪問。 > - 形參1、返回值1:形參1、返回值1中參數變量名可以省略 ## 實現接口條件 接口就是規定了一個**需要實現的方法列表**,在 Go 語言中一個類型只要實現了接口中規定的所有方法,那么我們就稱它實現了這個接口。 ```go // Penson 是人類的結構體 type Penson struct { Name string } // Sing 是 Penson 結構體唱歌的方法 func (p Penson) Sing() { fmt.Printf("%s優美動聽的歌聲~", p.Name) } // Singer 接口 type Singer interface { Sing() } ``` 上述的案例就是 `Penson` 實現 `Singer` 接口。如果接口定義多個方法的話, `Penson` 也需要定義對應的方法才能實現到 `Singer` 接口 ## 為什么需要使用接口 現在支付方式有微信、支付寶、銀行卡等等,每個支付流程都不一樣。各自開發一個二維碼來收錢。對于客戶而言,需要找對應的二維碼才能進行支付,這種體驗感不算太友好。 如果有一個萬能二維碼都可以付款的話,對于客戶來說,這種體驗感比較友好。在 Golang 語言中就是接口。 ## 面向接口編程 編程過程很多時候可以使用到接口的。比如動作屬性,很多類型都有這類動作的話,那么就可以實現到接口方式了。例如,支付方式、發聲、跑步、睡覺和求面積體積等等 這里舉例結賬功能。微信、支付寶都有支付功能。這里創建一個結賬接口,然后所有付款都可以對接進來結賬的。后續有其他付款方式的話,結構體實現到支付的方法即可調用結賬的接口來付款。 ```go // WeChat 是微信結構體 type WeChat struct { ID int User string } // Pay 是微信結構體的付款方法 func (w WeChat) Pay(f float64) { fmt.Printf("%s用戶微信扣款%.2f元\n", w.User, f) } // Alipay 是支付寶結構體 type Alipay struct { ID int User string } // Pay 是支付寶結構體的付款方法 func (a Alipay) Pay(f float64) { fmt.Printf("%s用戶支付寶扣款%.2f元\n", a.User, f) } // Payer 結賬接口 type SettleAccounter interface { Pay(float64) } func main() { // 微信結構體賦值給w變量 w := WeChat{1, "jiaxzeng"} // 定義結賬類型變量 var s SettleAccounter // 將微信結構體賦值給接口 s = w // 接口調用微信結構體支付的方法 s.Pay(1.248) // 支付寶結賬方式 a := Alipay{2, "xiaodunan"} var s2 SettleAccounter = a s2.Pay(1.451) } // 運行結果: // jiaxzeng用戶微信扣款1.25元 // xiaodunan用戶支付寶扣款1.45元 ``` ## 接口類型變量 那實現了接口又有什么用呢?一個接口類型的變量能夠存儲所有實現了該接口的類型變量。 ```go // 微信結構體賦值給w變量 w := WeChat{1, "jiaxzeng"} // 定義結賬類型變量 var s SettleAccounter // 將微信結構體賦值給接口 s = w // 接口調用微信結構體支付的方法 s.Pay(1.248) // 支付寶結賬方式 a := Alipay{2, "xiaodunan"} var s2 SettleAccounter = a s2.Pay(1.451) ``` >[info] 上述舉例中 `WeChat` 和 `Alipay` 結構體均實現 `SettleAccounter` 接口,此時一個 `SettleAccounter` 類型的變量就能夠接收 `WeChat` 和 `Alipay` 類型的變量。
                  <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>

                              哎呀哎呀视频在线观看