Lorsque vous êtes chargé d'appliquer une fonction à chaque élément d'une liste et de compiler les résultats dans une nouvelle liste, vous pourriez trouver vous-même en utilisant une approche conventionnelle basée sur une boucle similaire à l'exemple ci-dessous :
list := []int{1, 2, 3} list2 := []int{} for _, x := range list { list2 := append(list2, multiply(x, 2)) } str := strings.Join(list2, ", ")
Bien que cette méthode remplisse son objectif, elle manque de la brièveté et de l'élégance trouvées dans la syntaxe de compréhension de Python.
Heureusement, avec l'introduction de Go 1.18, une fonction Map générique plus rationalisée a émergé :
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 }
Cette fonction Map permet une transformation beaucoup plus propre des éléments de la liste :
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) })
Avec cette nouvelle approche, vous pouvez appliquer des fonctions pour lister des éléments avec facilité et efficacité, dotant ainsi votre code Go du même niveau de concision et de puissance que celui de Python.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!