ホームページ >バックエンド開発 >C++ >カスタム JsonConverter を実装するときにデフォルトの System.Text.Json シリアル化動作を保持するにはどうすればよいですか?

カスタム JsonConverter を実装するときにデフォルトの System.Text.Json シリアル化動作を保持するにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2025-01-10 07:24:42773ブラウズ

How Can I Preserve Default System.Text.Json Serialization Behavior When Implementing a Custom JsonConverter?

デフォルトの動作を維持しながら System.Text.Json シリアル化をカスタマイズします

質問:

データ モデルのアップグレードのためにカスタム System.Text.Json.JsonConverter を実装する場合、他のシリアル化オプションに影響を与えずに、Write() メソッドのデフォルトのシリアル化動作を維持するにはどうすればよいですか?

答え:

カスタム System.Text.Json.JsonConverter の Write() メソッドでデフォルトのシリアル化動作を保持するには、次の戦略を使用できます:

オプション 1: 属性で [JsonConverter] を使用します

  • [JsonConverter] 属性を特定のプロパティに適用します。
  • カスタム オプションを指定せずに JsonSerializer.Serialize() を呼び出すと、デフォルトのシリアル化が生成されます。

オプション 2: コンバーター コレクションを変更する

  • Write() メソッド内で、渡されたオプションのコピーを作成し、Converters コレクションからカスタム コンバーターを削除します。
  • 変更されたオプションをネストされた JsonSerializer 呼び出しに渡します。

オプション 3: DefaultConverterFactory を実装する

  • デフォルトのコンバーターをラップするカスタム コンバーター ファクトリ (例: DefaultConverterFactory) を定義します。
  • ファクトリの CanConvert() メソッドは、コンバータが適用可能かどうかを判断します。
  • ファクトリの CreateConverter() メソッドは、変更されたオプションを使用してコンバータを作成します (カスタム コンバータを除く)。

制限事項:

  • オプション 3 は、型自体に [JsonConverter] 属性を持つカスタム値型または POCO では機能しません。
  • 変更されたオプションが一貫して適用されないため、再帰型では問題が発生する可能性があります。

例:

<code class="language-csharp">public sealed class PersonConverter : DefaultConverterFactory<Person>
{
    public override Person Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions modifiedOptions)
    {
        // 自定义读取实现
    }
}

public abstract class DefaultConverterFactory<T> : JsonConverterFactory
{
    public override bool CanConvert(Type typeToConvert) => typeof(T) == typeToConvert;

    public override JsonConverter CreateConverter(Type typeToConvert, JsonSerializerOptions options)
    {
        return new DefaultConverter(options, this);
    }
}

public sealed class DefaultConverter : JsonConverter<Person>
{
    public override void Write(Utf8JsonWriter writer, Person value, JsonSerializerOptions modifiedOptions)
    {
        // 调用默认的 Write 实现
        JsonSerializer.Serialize(writer, value, modifiedOptions);
    }
}</code>

以上がカスタム JsonConverter を実装するときにデフォルトの System.Text.Json シリアル化動作を保持するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。