Go 言語のジェネリックスは複数型のサポートを提供し、開発者が複数の型に使用できるコードを作成できるようにします。ジェネリック構文は、型名で型パラメーターを指定することによってジェネリック型を宣言し、関数呼び出しで型パラメーターを自動的に推論します。ジェネリックは比較可能な型をサポートしており、カスタム比較関数を使用してさまざまな型を並べ替えるユニバーサル並べ替えアルゴリズムなどの共通のアルゴリズムと関数の作成に使用できます。
Go 言語では、バージョン 1.18 でジェネリックス機能が導入され、開発者が複数型のコードを作成できるようになりました。ジェネリックにより、コードの再利用性と柔軟性が向上します。
ジェネリック型を宣言する場合は、型名の角かっこで型パラメーターを指定する必要があります。
func Max[T comparable](a, b T) T { if a > b { return a } return b }
関数でジェネリック型を使用する場合を呼び出すと、Golang コンパイラは自動的に型パラメータを推論します:
fmt.Println(Max(1, 2)) // 输出:2 fmt.Println(Max(1.2, 3.4)) // 输出:3.4 fmt.Println(Max("Hello", "Wolrd")) // 输出:Wolrd
ジェネリック型は比較可能な型 (comparable
) のみをサポートすることに注意してください。
ジェネリックスを使用すると、あらゆる型に適用できるユニバーサル ソート アルゴリズムを作成できます:
func Sort[T any](arr []T, less func(T, T) bool) { for i := 0; i < len(arr); i++ { for j := 0; j < len(arr)-1-i; j++ { if less(arr[j], arr[j+1]) { arr[j], arr[j+1] = arr[j+1], arr[j] } } } }
カスタム比較関数を使用すると、このソートが可能になります。アルゴリズムはさまざまな型に使用されます。
func SortInts(arr []int) { Sort(arr, func(a, b int) bool { return a < b }) } func SortStrings(arr []string) { Sort(arr, func(a, b string) bool { return a < b }) }
Go 言語のジェネリック機能は強力な複数型のサポートを提供し、開発者が再利用可能で柔軟なコードを作成できるようにします。上記で紹介した手法を使用すると、さまざまなタイプで機能する汎用アルゴリズムと関数を簡単に作成できます。
以上がGo 言語のジェネリックスは複数型のサポートを実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。