好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > golang 接口嵌套實現復用的操作

golang 接口嵌套實現復用的操作

熱門標簽:百度地圖標注后傳給手機 電話機器人軟件免費 評價高的400電話辦理 外呼系統顯本地手機號 阿克蘇地圖標注 外呼系統用什么卡 涿州代理外呼系統 excel地圖標注分布數據 壽光微信地圖標注

大家還是直接看代碼吧~

package main
import (
    "fmt"
)
func main() {
    start(NewB(C{}))
    start(NewB(D{}))
}
type A interface {
    what()
}
type B struct {
    A
}
type C struct {
}
func (b C) what() {
    fmt.Println("this is type C")
}
type D struct {
}
func (b D) what() {
    fmt.Println("this is type D")
}
func start(b B) {
    b.what()
}
func NewB(a A) B {
    return B{a}
}

補充:【玩轉Golang】通過組合嵌入實現代碼復用

應用開發中的一個常見情景,為了避免簡單重復,需要在基類中實現共用代碼,著同樣有助于后期維護。

如果在以往的支持類繼承的語言中,比如c++,Java,c#等,這很簡單!可是go不支持繼承,只能mixin嵌入

且看下面的代碼:

type ManKind interface{
    Say(s string);   
    GetMouth()string
}
type Man struct{
   
}
func NewMan() ManKind{
    return Man{};
}
func (this *Man)GetMouth()string{
    return "M0"
}
func (this *Man) Say(s string){
    fmt.Printf("\n Speak with mouth[%s] : \"%s\"",this.GetMouth(),s);
}
type StrongMan struct{
    Man
}
func NewStrongMan()ManKind{
    return StrongMan{}
}
func (this*StrongMan)GetMouth()string{
    return "M1"
}
func main(){    
    NewMan().Say("good luck!")
    NewStrongMan().Say("good luck!")
}

如果支持繼承,很明顯應該輸出

Speak with mouth[M0] : "good luck!"

Speak with mouth[M1] : "good luck!"

但是在golang中只能輸出:

Speak with mouth[M0] : "good luck!"

Speak with mouth[M0] : "good luck!"

StrongMan中調用Say(),此時可以將指針傳遞到內嵌類,只是簡單的指向了Man的方法,在ManKind中調用GetMouth就是ManKind自己的GetMouth,和StrongMan沒有關系。

當然,我們可以在StrongMan中覆蓋Say方法

func (this *StrongMan)Say(s string){
    fmt.Printf("\n Speak with mouth[%s] : \"%s\"",this.GetMouth(),s);
}

此時,當然可以正確輸出,因為本來調用的就都是StrongMan自己的方法了,這又和我們的初衷相違背了。那么這種情況怎么實現呢?我的方法是,讓Man再臟一點兒,把需要的東西傳遞給組合進來的類。

給Man增加一個屬性mouth,增加一個SetMouth方法,修改一下GetMouth方法,StrongMan的GetMouth方法刪除掉,再修改一下NewStrongMan方法

最后的代碼如下:

package main
import(
    "fmt"
)
type ManKind interface{
    Say(s string);    
    SetMouth(m string)
    GetMouth()string
}
type Man struct{
    ManKind    
    mouth string
}
func NewMan() ManKind{
    return Man{mouth:"M0"};
}
func (this *Man)GetMouth()string{
    return this.mouth;
}
func (this *Man)SetMouth(s string){
    this.mouth=s;
}
func (this *Man) Say(s string){
    fmt.Printf("\n Speak with mouth[%s] : \"%s\"",this.GetMouth(),s);
}
type StrongMan struct{
    Man
}
func NewStrongMan()ManKind{
    sm := StrongMan{}
  sm.SetMouth("M1");
  return sm;
}
    
func main(){    
    NewMan().Say("good luck!")
    NewStrongMan().Say("good luck!")
}

當然,如果你不愿意用Get、Set方法,也可以直接輸出Man的Mouth屬性。

我總結的嵌入式編程要點:

1,被嵌入的類的方法,只能訪問他自己的字段,包裝類即時聲明了同名字段也沒用。

2,包裝類可以覆蓋嵌入類的方法,但是嵌入類訪問不到,亦然訪問自己的方法。只能在包裝類中連同調用方法一同實現。

3,包裝類覆蓋嵌入類字段后,亦然可以通過嵌入類的類名訪問嵌入類的字段。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • 淺談Golang 嵌套 interface 的賦值問題
  • golang中的空接口使用詳解
  • 如何判斷Golang接口是否實現的操作
  • golang接口IP限流,IP黑名單,IP白名單的實例
  • Golang 使用接口實現泛型的方法示例
  • golang分層測試之http接口測試入門教程
  • golang基礎之Interface接口的使用

標簽:汕頭 蘭州 雞西 梅河口 重慶 吐魯番 欽州 銅川

巨人網絡通訊聲明:本文標題《golang 接口嵌套實現復用的操作》,本文關鍵詞  golang,接口,嵌套,實現,復,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang 接口嵌套實現復用的操作》相關的同類信息!
  • 本頁收集關于golang 接口嵌套實現復用的操作的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 中国丰满女人特级A片| 日韩精品一区二区亚洲AV观看 | 麻豆+无码+国产在线观看 | 硕大蘑菇头顶开粉嫩的小缝| 精品日韩人妻一区二区三中文字幕 | 十三路末班车电影完整版在线观看| 比较有肉的黑道文| 亚洲Av秘?无码一区二区| 国产精品???色欲A片借| 男生和女生搞鸡的视频| 一家人乱淫| 免费中文字幕精品毛片| 欧美高清一区二区三| 91在线无码精品秘?入口不卡| 黑人啊灬啊灬快灬深-欧洲无码精| 男主与女二疯狂做h| 灯草和尚2未删减版本在线观看 | 精品一级A片一区二区免费视频 | 我与亲生的性关系自述| 全球最大影库永久免费| 被窝午夜理论影片| 无翼全污彩色无遮挡| 自己安慰自己的视频教程| 美女的隐私免费视频播放| 欧美亚洲日本一区二区三区浪人 | 肥婆p出处大| 国产美女包臀裙一区二区| 免费看无码一级A片放24小时| 羞羞视频免费网站在线看| 男女交配视频| 亚洲熟妇色????APP| 免费的毛片视频| 国产精品???黄桃在线观看官网| chineseGay高二勃起| 69av在线播放| 18美女的隐私视频网站| 亚洲小说春色综合另类电影| 亚洲国产一区二区三区精品 | xxx日本18| 人妻裸体拍摄中文字幕| 国产网红主播精品无码一区|