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

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

Linda Hamilton
Linda Hamiltonオリジナル
2024-11-10 15:37:03684ブラウズ

How Can Go's Map Function Streamline List Element Transformation?

Go で要素をリストするための関数アプリケーションの簡潔な実装

リストの各メンバーに変換を適用して結果を保存する場合新しいリストでは、明示的なループに頼るのが一般的です。ただし、Python では、以下に示すように、リスト内包表記が簡潔な代替手段を提供します。

list = [1,2,3]
str = ', '.join(multiply(x, 2) for x in list)

Go では、同様のアプローチにより、より冗長なループ構造が必要になります。

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

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

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

ただし、Go 1.18 では、Map 関数を使用した洗練されたソリューションが導入されています。 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
}
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 の Map 関数はどのようにしてリスト要素の変換を効率化できるのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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