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
Libérer: 2024-12-31 15:09:10
original
441 Les gens l'ont consulté

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())
}
Copier après la connexion

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: []
Copier après la connexion

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)
    }
}
Copier après la connexion

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]
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal