當負責將函數應用於列表中的每個元素並將結果編譯到新列表中時,您可能會發現您自己使用類似於以下示例的傳統的基於循環的方法:
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中文網其他相關文章!