Maison >développement back-end >Golang >Comment Go 1.18 peut-il rationaliser la transformation des éléments de liste ?

Comment Go 1.18 peut-il rationaliser la transformation des éléments de liste ?

DDD
DDDoriginal
2024-11-24 07:15:09257parcourir

How Can Go 1.18  Streamline List Element Transformation?

Transformation rapide et facile des éléments de liste dans Go

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn