Maison >développement back-end >Golang >Pourquoi ne puis-je pas obtenir l'adresse d'un littéral de chaîne dans Go ?
Adressage des littéraux de chaîne dans Go
Dans les applications impliquant des passages fréquents de références à des chaînes statiques, des problèmes d'allocation de mémoire surviennent. Cet article aborde la raison de l'impossibilité d'obtenir l'adresse des chaînes littérales et explore les solutions potentielles.
Pourquoi la récupération d'adresse échoue
La récupération de l'adresse d'une chaîne littérale est pas réalisable dans Go en raison d'une sémantique ambiguë. Le langage fait la distinction entre prendre l'adresse de la valeur constante elle-même, ce qui pourrait modifier la valeur et potentiellement conduire à des erreurs d'exécution, et allouer un nouvel objet, copier la constante et acquérir l'adresse de cette nouvelle version.
Contrairement au littéral du test1() fourni, test2() démontre une approche valide. En utilisant une variable existante avec une sémantique bien définie, Go évite l'ambiguïté associée aux littéraux. Cependant, cette approche ne s'appliquerait pas aux constantes, ce qui souligne encore davantage l'interdiction de la récupération d'adresse littérale.
Solution optimale : test2()
La solution recommandée consiste à utiliser le approche test2(). Bien que cela puisse nécessiter un code légèrement plus détaillé, il s'aligne sur les règles claires et concises de Go concernant la récupération d'adresses. En créant une variable dédiée et en prenant l'adresse de cette variable, le besoin d'adressage littéral est contourné.
Exception : les littéraux composites
Il existe une exception à la règle générale dans le cas de littéraux composites, qui permettent la création et l'adressage de structures anonymes. Cette exception, décrite dans la spécification du langage, autorise du code tel que :
func f() interface{} { return &struct { A int B int }{1, 2} }
Bien que cette exception fournisse un moyen alternatif de récupération d'adresse, la clarté et la simplicité de la solution test2() restent l'approche privilégiée pour la plupart des scénarios.
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!