ホームページ >バックエンド開発 >Golang >Go 言語のジェネリックスは複数型のサポートを実装します

Go 言語のジェネリックスは複数型のサポートを実装します

王林
王林オリジナル
2024-04-03 11:21:011183ブラウズ

Go 言語のジェネリックスは複数型のサポートを提供し、開発者が複数の型に使用できるコードを作成できるようにします。ジェネリック構文は、型名で型パラメーターを指定することによってジェネリック型を宣言し、関数呼び出しで型パラメーターを自動的に推論します。ジェネリックは比較可能な型をサポートしており、カスタム比較関数を使用してさまざまな型を並べ替えるユニバーサル並べ替えアルゴリズムなどの共通のアルゴリズムと関数の作成に使用できます。

Go 言語のジェネリックスは複数型のサポートを実装します

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 サイトの他の関連記事を参照してください。

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