Go では、同じメソッド シグネチャを持つが別個のパッケージで定義されている複数のインターフェイスを処理する場合、次のような状況が発生することがあります。両方のインターフェイスを実装した型は、予期しない動作を引き起こします。
異なるパッケージで定義されている次の 2 つのインターフェイス (Doer) と関数 (FuncA と FuncB) について考えてみましょう:
// Package A
type Doer interface { Do() string }
func FuncA(doer Doer)
// Package B
type Doer interface { Do() string }
func FuncB(doer Doer)
タイプ C が両方のパッケージの Doer を実装し、実装が異なる場合:
// Package main
type C int
func (c C) Do() string { return "A-specific implementation" }
func main() {
cA := C(0); A.FuncA(cA)
cB := C(0); B.FuncB(cB) // Behavior differs due to varying `Do()` implementations
}
この問題に対処するために、Go の型システムは名前による一致と型の一貫性を重視します。オブジェクトが複数のインターフェイスを満たすことは可能ですが、共有メソッドの実装は、該当するすべてのインターフェイス規約に従う必要があります。
上記のシナリオでは、回避策としてラッパー タイプを実装する必要があります。
// Package main
type DoerA struct { C C }
func (d DoerA) Do() string { return "A-specific implementation" }
type DoerB struct { C C }
func (d DoerB) Do() string { return "B-specific implementation" }
func main() {
cA := DoerA{C(0)}; A.FuncA(cA)
cB := DoerB{C(0)}; B.FuncB(cB) // Correct behavior with separate implementations
}
これらのラッパーを作成することで、意図したインターフェイスの使用法に基づいて Do() の実装を制御し、それぞれのパッケージ コンテキスト内での一貫性を確保できます。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3