Maison > Article > développement back-end > Comment puis-je appliquer efficacement une fonction à chaque élément d'une liste Go ?
Application efficace de fonctions aux listes dans Go
Pour appliquer une fonction à chaque élément d'une liste Go et stocker les résultats dans une nouvelle liste , l'approche traditionnelle consiste à parcourir la liste d'entrée et à ajouter les résultats à la liste de sortie. Cependant, avec Go 1.18 et supérieur, il existe une solution plus concise et générique : la fonction Map.
La fonction Map prend une liste d'éléments de type T et une fonction qui convertit chaque élément en une valeur de type V. Il renvoie une nouvelle liste de type []V contenant les résultats de l'application de la fonction à chaque élément de la liste d'entrée.
Voici un exemple :
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 } // Usage example 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) })
Dans cet exemple, l'entrée est une liste d'entiers. Nous pouvons appliquer la fonction Map avec deux fonctions différentes pour créer une liste d'entiers incrémentés (outputInts) et une liste de chaînes formatées (outputStrings). Cela élimine le besoin de boucles explicites et offre une alternative concise et efficace à l'approche traditionnelle.
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!