Maison >développement back-end >Golang >Pourquoi l'ajout à une tranche dans une méthode de structure Golang ne fonctionne-t-il pas à moins qu'un récepteur de pointeur ne soit utilisé ?

Pourquoi l'ajout à une tranche dans une méthode de structure Golang ne fonctionne-t-il pas à moins qu'un récepteur de pointeur ne soit utilisé ?

Linda Hamilton
Linda Hamiltonoriginal
2024-12-31 15:09:10453parcourir

Why doesn't appending to a slice within a Golang struct method work unless a pointer receiver is used?

Pourquoi ne puis-je pas ajouter à une tranche qui est la propriété d'une structure en Golang ?

En Golang, tout est transmis par valeur , ce qui signifie qu'une copie d'un objet est créée chaque fois qu'il est passé en argument à une fonction. Cela peut entraîner un comportement inattendu lorsque vous essayez d'ajouter à une tranche qui est une propriété d'une structure.

Le problème : Test3

Considérez l'exemple suivant :

package main

import "fmt"

type Test3 struct {
    all []int
}

func (c Test3) run() []int {
    c.combo()
    return c.all
}

func (c Test3) combo() {
    for i := 0; i < 2; i++ {
        c.all = append(c.all, i)
        fmt.Println("Test3 step", i+1, c.all)
    }
}

func main() {
    test3 := &Test3{}
    fmt.Println("Test3 final:", test3.run())
}

Lorsque vous appelez test3.run(), il crée une copie de test3 et la transmet pour s'exécuter. La méthode run appelle ensuite combo, qui ajoute deux valeurs à c.all. Cependant, au retour de run, les modifications apportées à c.all sont perdues car la copie de test3 est supprimée. Cela entraîne le renvoi d'une tranche vide, comme le montre le résultat :

Test3 step 1 [0]
Test3 step 2 [0 1]
Test3 final: []

La solution : utiliser un récepteur de pointeur

Pour résoudre ce problème, vous devez d'utiliser un récepteur pointeur pour la méthode combo. Cela indique au compilateur de transmettre un pointeur vers la valeur Test3 au lieu d'une copie.

func (c *Test3) combo() {
    for i := 0; i < 2; i++ {
        c.all = append(c.all, i)
        fmt.Println("Test3 step", i+1, c.all)
    }
}

Avec le récepteur de pointeur, les modifications apportées à c.all dans le combo sont directement appliquées à la valeur Test3 d'origine, puisque il est adopté par référence. Cela donne le résultat correct :

Test3 step 1 [0]
Test3 step 2 [0 1]
Test3 final: [0 1]

En comprenant le concept de transmission par valeur et en utilisant les récepteurs de pointeurs de manière appropriée, vous pouvez éviter un comportement inattendu lorsque vous travaillez avec des tranches dans des structures Golang.

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