本文實例講述了Go語言使用組合的方式實現(xiàn)多繼承的方法。分享給大家供大家參考。具體實現(xiàn)方法如下:
在大多數(shù)面向?qū)ο蟮木幊陶Z言中多繼承都是不支持的。因為在基于class的體系中,多繼承極大地增加了編譯器的復雜性。
Go語言使用組合的方式實現(xiàn)繼承,因此也可以很簡單的實現(xiàn)多繼承。
復制代碼 代碼如下:
//使用組合的方式實現(xiàn)多繼承
type Phone struct{}
func (p *Phone) Call() string {
return "Ring Ring"
}
type Camera struct{}
func (c *Camera) TakeAPicture() string {
return "Click"
}
//多繼承
type CameraPhone struct {
Camera
Phone
}
func structTest0803() {
cp := new(CameraPhone)
fmt.Println("Our new CameraPhone exhibits multiple behaviors ...")
fmt.Println("It exhibits behavior of a Camera: ", cp.TakeAPicture())
fmt.Println("It works like a Phone too: ", cp.Call())
/*Output:
Our new CameraPhone exhibits multiple behaviors ...
It exhibits behavior of a Camera: Click
It works like a Phone too: Ring Ring
*/
}
希望本文所述對大家的Go語言程序設計有所幫助。
您可能感興趣的文章:- Golang正整數(shù)指定規(guī)則排序算法問題分析
- Golang最大遞減數(shù)算法問題分析
- Go語言展現(xiàn)快速排序算法全過程的思路及代碼示例
- 深入解析快速排序算法的原理及其Go語言版實現(xiàn)
- GO語言利用K近鄰算法實現(xiàn)小說鑒黃
- Go語言實現(xiàn)漢諾塔算法
- Go語言通過Luhn算法驗證信用卡卡號是否有效的方法
- go語言睡眠排序算法實例分析
- Go語言實現(xiàn)AzDG可逆加密算法實例
- Go語言實現(xiàn)的樹形結(jié)構(gòu)數(shù)據(jù)比較算法實例
- Go語言算法之尋找數(shù)組第二大元素的方法
- Golang排列組合算法問題之全排列實現(xiàn)方法