Maison >développement back-end >C++ >Comment puis-je obtenir une sérialisation par défaut dans les convertisseurs personnalisés System.Text.Json sans modifier la méthode d'écriture ?

Comment puis-je obtenir une sérialisation par défaut dans les convertisseurs personnalisés System.Text.Json sans modifier la méthode d'écriture ?

Barbara Streisand
Barbara Streisandoriginal
2025-01-10 09:31:40197parcourir

How Can I Achieve Default Serialization in System.Text.Json Custom Converters Without Modifying the Write Method?

Utiliser un convertisseur personnalisé pour gérer la sérialisation par défaut

Lors de la création d'un System.Text.Json.JsonConverter personnalisé, vous n'aurez peut-être pas toujours besoin de modifier la méthode Write() car vous n'avez besoin d'aucune sérialisation personnalisée. Cet article décrit comment générer automatiquement la sérialisation par défaut pour éviter d'utiliser un comportement personnalisé dans la méthode Write().

Contexte

JsonConverter est appliqué aux propriétés, objets ou types en fonction de leur priorité. Les situations suivantes existent :

  • Convertisseurs personnalisés appliqués aux propriétés
  • Convertisseurs ajoutés à la collection Convertisseurs
  • Convertisseurs appliqués aux types de valeurs personnalisés ou POCO
  • Convertisseurs renvoyés par JsonConverterFactories

Chaque situation est gérée différemment.

Méthode de sérialisation par défaut

  1. Convertisseurs appliqués aux attributs :
  • La sérialisation par défaut peut être générée en appelant simplement JsonSerializer.Serialize(writer, person, options).
  1. Convertisseurs ajoutés à la collection Convertisseurs :
  • Créez une copie de JsonConverterOptions avec le convertisseur personnalisé supprimé.
  • Transmettez la copie modifiée à JsonSerializer.Serialize(Utf8JsonWriter, T, JsonSerializerOptions).
  • Notez que cette approche peut poser des difficultés avec les types récursifs.
  1. Convertisseurs appliqués aux types de valeurs personnalisés ou POCO :
  • Il n'existe aucun moyen de générer directement la sérialisation par défaut.

pour des usines et des extensions personnalisées pratiques

Pour simplifier le processus, vous pouvez créer une fabrique personnalisable qui vous permet de gérer la sérialisation personnalisée sans modifier la méthode Write() :

<code>public class DefaultConverterFactory<T> : JsonConverterFactory
{
    // 此处为内部 DefaultConverter 实现
}</code>

Cette usine sert de base aux convertisseurs personnalisés qui gèrent la création de copies de JsonSerializerOptions (les convertisseurs personnalisés ont été supprimés). Options modifiées pour la sérialisation par défaut dans la méthode Write().

<code>public class PersonConverter : DefaultConverterFactory<Person>
{
    // 此处为 Read 和 Write 方法实现
}</code>

En utilisant la classe de base DefaultConverterFactory, vous pouvez vous assurer que la méthode Write() effectue la sérialisation par défaut tout en conservant un comportement personnalisé dans la méthode Read().

Autres notes

  • Appliquer DefaultConverterFactory directement à un type de valeur personnalisé ou POCO déclenchera un débordement de pile.
  • Lorsque vous essayez d'implémenter cette méthode sur un convertisseur renvoyé par une usine, il est important de déterminer s'il faut désactiver l'ensemble de l'usine ou uniquement pour des types spécifiques.

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