ホームページ >バックエンド開発 >Golang >Go 1.18 はどのようにしてリスト要素の変換を効率化できるのでしょうか?

Go 1.18 はどのようにしてリスト要素の変換を効率化できるのでしょうか?

DDD
DDDオリジナル
2024-11-24 07:15:09257ブラウズ

How Can Go 1.18  Streamline List Element Transformation?

Go での迅速かつ簡単なリスト要素の変換

リスト内の各要素に関数を適用し、その結果を新しいリストにコンパイルするというタスクを実行すると、次のことがわかります。以下の例のような従来のループベースのアプローチを利用してください:

list := []int{1, 2, 3}
list2 := []int{}

for _, x := range list {
    list2 := append(list2, multiply(x, 2))
}

str := strings.Join(list2, ", ")

このメソッドはその目的を果たしますが、 Python の内包構文に見られる簡潔さと優雅さが欠けています。

幸いなことに、Go 1.18 の導入により、より合理化された汎用 Map 関数が登場しました。

func Map[T, V any](ts []T, fn func(T) V) []V {
    result := make([]V, len(ts))
    for i, t := range ts {
        result[i] = fn(t)
    }
    return result
}

この Map 関数では、リスト要素のよりクリーンな変換:

input := []int{4, 5, 3}
outputInts := Map(input, func(item int) int { return item + 1 })
outputStrings := Map(input, func(item int) string { return fmt.Sprintf("Item:%d", item) })

この新しいアプローチでは、関数を簡単かつ効率的にリスト要素に適用できるため、Go コードに Python と同じレベルの簡潔さとパワーを与えることができます。

以上がGo 1.18 はどのようにしてリスト要素の変換を効率化できるのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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