Rumah >pembangunan bahagian belakang >Golang >Bagaimana Boleh Pergi 1.18 Memperkemas Transformasi Elemen Senarai?
Apabila ditugaskan untuk menggunakan fungsi pada setiap elemen dalam senarai dan menyusun keputusan ke dalam senarai baharu, anda mungkin mendapati sendiri menggunakan pendekatan berasaskan gelung konvensional yang serupa dengan contoh di bawah:
list := []int{1, 2, 3} list2 := []int{} for _, x := range list { list2 := append(list2, multiply(x, 2)) } str := strings.Join(list2, ", ")
Walaupun kaedah ini memenuhi tujuannya, ia tidak mempunyai keringkasan dan keanggunan yang terdapat dalam sintaks pemahaman Python.
Mujurlah, dengan pengenalan Go 1.18 , fungsi Peta generik yang lebih diperkemas telah muncul:
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 }
Fungsi Peta ini membolehkan transformasi elemen senarai yang lebih bersih:
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) })
Dengan pendekatan baharu ini, anda boleh menggunakan fungsi untuk menyenaraikan elemen dengan mudah dan cekap, memperkasakan kod Go anda dengan tahap ringkas dan kuasa yang sama yang terdapat dalam Python.
Atas ialah kandungan terperinci Bagaimana Boleh Pergi 1.18 Memperkemas Transformasi Elemen Senarai?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!