首頁 >後端開發 >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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn