ホームページ >バックエンド開発 >Golang >インターフェイスを使用して Go ジェネリクスで再帰型制約をどのように実現できますか?

インターフェイスを使用して Go ジェネリクスで再帰型制約をどのように実現できますか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-12-26 15:22:10112ブラウズ

How Can Recursive Type Constraints Be Achieved in Go Generics Using Interfaces?

定義済み型による再帰型制約

Go ジェネリックスでは、インターフェイスを使用してジェネリック型に型制約を指定できます。ただし、ジェネリック型の引数を使用してメソッドの実装を強制するのは難しい場合があります。

Go ジェネリックスで再帰的な型制約を実現するには、ジェネリック型を受け取るメソッドとのインターフェイスを次のように定義できます。引数:

type Lesser[T any] interface {
    Less(T) bool
}

次に、Lesser[T] 型の 2 つの引数を受け取り、 boolean:

func IsLess[T Lesser[T]](x, y T) bool {
    return x.Less(y)
}

Lesser[T] インターフェイスを実装するカスタム型を関数で使用できるようになりました:

type Apple int

func (a Apple) Less(other Apple) bool {
    return a < other
}

type Orange int

func (o Orange) Less(other Orange) bool {
    return o < other
}

func main() {
    fmt.Println(IsLess(Apple(10), Apple(20)))   // true
    fmt.Println(IsLess(Orange(30), Orange(15))) // false
}

Lesser[T] 制約により、指定された型がIsLess 関数に、同じ型の引数を取る Less メソッドを実装します。これにより、型リテラルを使用せずに再帰的な型制約が可能になります。

以上がインターフェイスを使用して Go ジェネリクスで再帰型制約をどのように実現できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。