Golang之繼承類比

來源:互聯網
上載者:User
這是一個建立於 的文章,其中的資訊可能已經有所發展或是發生改變。

問題由一個需求引起:

web的controller,希望建立一個基類,然後在子類的controller中定義action方法,基類有一個run函數能根據字串自動找到子類的action方法。

 

如何解決呢? -- 用繼承

樣本分析繼承

首先這個需求是很普遍的,由於腦中有繼承概念,所以想當然地以為這個很容易實現:

package mainimport("reflect")type A struct {}func (self A)Run() {c := reflect.ValueOf(self)method := c.MethodByName("Test")println(method.IsValid())}type B struct {A}func (self B)Test(s string){println("b")}func main() {b := new(B)b.Run()}

B繼承A,B中調用Run方法,自然會調用到A的Run方法,然後我根據string“Test”,希望能找到B中(B是子類)的Test方法。

 

 

用繼承的觀點看沒錯,實際運行呢?method.IsValid() 返回false。很明顯,這裡的Test方法是找不到的。

 

分析問題,首先這裡“繼承”兩個詞就用錯了,在go中不應該提及“繼承”這個詞,我更選擇使用“嵌套”這個詞。B是嵌套了A,所以這裡的b.Run()實際上是文法糖,調用的是b.A.Run()。這裡Run的全部環境都在A中。所以是找不到A的Test的。

 

感謝@hongqirui和@海意,在它們幫忙下找到瞭解決方法:

package mainimport("reflect")type A struct {Parent interface{}}func (self A)Run() {c := reflect.ValueOf(self.Parent)method := c.MethodByName("Test")println(method.IsValid())}type B struct {A}func (self B)Test(s string){println("b")}func (self B)Run(){self.A.Run()}func main() {b := new(B)b.A.Parent = bb.Run()}

在父類中加一個interface{}記錄子類!!這樣問題就迎刃而解了!method.IsValid()返回了true。

 

結論

所以在golang中要類比普通的繼承,除了使用嵌套之外,還需要在父類中“註冊”子類的資訊

 

外友情幫忙推薦下@海意 所在公司的團隊自產自銷的web架構golanger。https://github.com/golangers

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.