本文實(shí)例講述了Golang繼承模擬實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
問題由一個(gè)需求引起:
web的controller,希望創(chuàng)建一個(gè)基類,然后在子類的controller中定義action方法,基類有一個(gè)run函數(shù)能根據(jù)字符串自動(dòng)找到子類的action方法。
如何解決呢? -- 用繼承
示例分析繼承
首先這個(gè)需求是很普遍的,由于腦中有繼承概念,所以想當(dāng)然地以為這個(gè)很容易實(shí)現(xiàn):
復(fù)制代碼 代碼如下:
package main
import(
"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中調(diào)用Run方法,自然會(huì)調(diào)用到A的Run方法,然后我根據(jù)string“Test”,希望能找到B中(B是子類)的Test方法。
用繼承的觀點(diǎn)看沒錯(cuò),實(shí)際運(yùn)行呢?method.IsValid() 返回false。很明顯,這里的Test方法是找不到的。
分析問題,首先這里“繼承”兩個(gè)詞就用錯(cuò)了,在go中不應(yīng)該提及“繼承”這個(gè)詞,我更選擇使用“嵌套”這個(gè)詞。B是嵌套了A,所以這里的b.Run()實(shí)際上是語法糖,調(diào)用的是b.A.Run()。這里Run的全部環(huán)境都在A中。所以是找不到A的Test的。
感謝@hongqirui和@海意,在它們幫忙下找到了解決方法:
復(fù)制代碼 代碼如下:
package main
import(
"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 = b
b.Run()
}
在父類中加一個(gè)interface{}記錄子類!!這樣問題就迎刃而解了!method.IsValid()返回了true。
結(jié)論
所以在golang中要模擬普通的繼承,除了使用嵌套之外,還需要在父類中“注冊(cè)”子類的信息!
希望本文所述對(duì)大家Go語言程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- Go語言使用組合的方式實(shí)現(xiàn)多繼承的方法
- 使用Go語言簡(jiǎn)單模擬Python的生成器
- Go語言模擬while語句實(shí)現(xiàn)無限循環(huán)的方法
- golang兩種調(diào)用rpc的方法
- golang中strconv.ParseInt函數(shù)用法示例
- golang簡(jiǎn)單讀寫文件示例
- golang image圖片處理示例
- golang基于websocket實(shí)現(xiàn)的簡(jiǎn)易聊天室程序
- golang使用sort接口實(shí)現(xiàn)排序示例
- golang守護(hù)進(jìn)程用法示例