1 回答

TA貢獻1875條經(jīng)驗 獲得超3個贊
永遠記住,Go 不支持inheritance. 它支持composition.
你可以call繼承它,只要它能幫助你在其他 OOP 語言和 Go 之間進行邏輯映射。經(jīng)驗法則,只要某些東西不像它在OOP世界上的運作方式那樣運作,就從構(gòu)圖的角度來思考。
is a但是當涉及到編寫實際代碼時,請始終記住組合中沒有任何關(guān)系,并且它始終是has a,即使看起來并非如此,因為事實上您實際上可以訪問composed/embedded(still, not inherited)的成員變量和方法)結(jié)構(gòu)。override如果您使用新結(jié)構(gòu)聲明相同的方法,您甚至可以使用該方法。這是另一個問題 - 您仍然無法訪問protected另一個包中結(jié)構(gòu)的未公開(接近 Java 世界)變量和函數(shù),就像您的情況一樣。
但是,您的類型RTree has rtree.RTree, but 永遠不會是 a rtree.RTree,并且對于編譯器來說永遠是不同的類型。
package main
import (
"github.com/intdxdt/rtree"
)
type RTree struct {
rtree.RTree
}
func NewRTree(nodeCap ...int) *RTree {
return &RTree{
RTree: *rtree.NewRTree(nodeCap...),
}
}
在一個單獨的節(jié)點上,除非你有更多的參數(shù)要添加,否則為什么不rtree.RTree直接使用呢?組合它,將為您提供封閉類型的所有方法,但您不能將它傳遞給任何需要封閉類型的函數(shù)。好消息是,您將隱式滿足封閉類型所滿足的接口,因此您可以將它傳遞給接受這些接口的函數(shù)。
- 1 回答
- 0 關(guān)注
- 102 瀏覽
添加回答
舉報