Comportement différent lors de l'impression d'octets.Buffer en Go
En Go, le comportement d'impression d'une valeur de type octets.Buffer varie en fonction de qu'il s'agisse d'un pointeur ou d'une valeur non-pointeur.
Considérez le code suivant exemple :
buf := new(bytes.Buffer) buf.WriteString("Hello world") fmt.Println(buf)
Dans ce cas, l'utilisation de l'opérateur * pour déréférencer le pointeur du tampon invoque la méthode String() de type bytes.Buffer. Cette méthode renvoie une représentation sous forme de chaîne du contenu du tampon, ce qui entraîne l'impression de "Hello World".
Maintenant, modifions le code comme suit :
var buf bytes.Buffer buf.WriteString("Hello world") fmt.Println(buf)
Sans utiliser l'opérateur *, nous transmettons une valeur non-pointeur de type bytes.Buffer. Contrairement à l'exemple précédent, le package fmt n'appelle pas la méthode String() dans ce cas. Au lieu de cela, il imprime le tampon sous forme de valeur de structure, en utilisant le formatage par défaut :
{[72 101 108 108 111 32 119 111 114 108 100] 0 [72 101 108 108 111 32 119 111 114 108 100 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0] 0}
Cette sortie représente la structure interne du bytes.Buffer, y compris la tranche supportant le tampon et les champs de longueur et de capacité.
La principale différence entre ces deux exemples réside dans la méthode String(). Lors de l'impression d'une valeur de type *bytes.Buffer, le package fmt utilise la méthode String() pour obtenir une représentation sous forme de chaîne du contenu du tampon. Étant donné que la valeur non-pointeur de type bytes.Buffer n'a pas cette méthode, le formatage de structure par défaut est utilisé.
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!