Maison > développement back-end > Golang > Pourquoi « json.Marshal() » de Go ne sérialise-t-il pas les champs structurels avec des préfixes minuscules ?

Pourquoi « json.Marshal() » de Go ne sérialise-t-il pas les champs structurels avec des préfixes minuscules ?

Mary-Kate Olsen
Libérer: 2024-12-21 21:44:46
original
544 Les gens l'ont consulté

Why Doesn't Go's `json.Marshal()` Serialize Struct Fields with Lowercase Prefixes?

Exploration des restrictions de génération JSON pour les champs Struct avec des préfixes minuscules dans Go

Dans Go, les développeurs rencontrent fréquemment un problème lorsqu'ils tentent de générer du JSON à partir de les structures qui possèdent des champs avec des caractères de préfixe minuscules. Comprendre la raison sous-jacente est essentiel pour résoudre efficacement ce problème.

Le problème survient en raison de la convention de Go pour identifier les identifiants publics dans un package. Les identifiants avec une lettre initiale majuscule sont considérés comme publics et sont accessibles en dehors du package. À l'inverse, les identifiants avec une lettre initiale minuscule sont considérés comme privés et ne sont visibles que dans le package actuel.

Considérez l'extrait de code suivant :

type Machine struct {
  m_ip string
  m_type string
  m_serial string
}
Copier après la connexion

Lorsque vous essayez de générer du JSON à partir d'une instance de cette structure utilisant json.Marshal(), vous pourriez rencontrer un résultat inattendu de simplement « {} ». En effet, les champs m_ip, m_type et m_serial ne sont pas visibles par json.Marshal() car ils sont considérés comme privés (indiqués par les préfixes minuscules).

Cependant, changer les champs en majuscules, comme indiqué ci-dessous , résoudra le problème :

type Machine struct {
  MachIp string
  MachType string
  MachSerial string
}
Copier après la connexion

En utilisant des préfixes majuscules, vous rendez ces champs accessibles au public, ce qui permet json.Marshal() pour générer avec succès la sortie JSON souhaitée.

Si vous avez besoin d'identifiants minuscules dans votre sortie JSON, vous pouvez utiliser le balisage de champ. En annotant chaque champ avec le nom JSON correspondant, vous pouvez remplacer le comportement par défaut. Par exemple :

type Machine struct {
    MachIp     string `json:"m_ip"`
    MachType   string `json:"m_type"`
    MachSerial string `json:"m_serial"`
}
Copier après la connexion

Grâce à ce mécanisme de balisage, vous pouvez spécifier explicitement les noms de champs JSON souhaités, quelle que soit leur casse initiale, vous permettant ainsi de créer des sorties JSON qui correspondent aux exigences de votre application.

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