ホームページ > バックエンド開発 > C++ > 「$type」フィールドを使用せずに、Json.Net でポリモーフィックな子オブジェクトのカスタム シリアル化を実現するにはどうすればよいですか?

「$type」フィールドを使用せずに、Json.Net でポリモーフィックな子オブジェクトのカスタム シリアル化を実現するにはどうすればよいですか?

Linda Hamilton
リリース: 2025-01-24 13:12:10
オリジナル
201 人が閲覧しました

How Can I Achieve Custom Serialization of Polymorphic Child Objects in Json.Net Without the

json.netカスタマイズされたマルチステートオブジェクトシリアル化、追加のタイプフィールド

質問:

json.netの

設定/誘導体の設定/逆のシーケンシャル化は非常に便利です。ただし、この方法では、シリアル化されたJSONに追加のTypeNameHandling.Autoフィールドが導入され、オーバーヘッドが増加します。 $type

解決策:

コーディングタイプの属性を備えたカスタムベースクラス:

コンテナクラスに保存されたサブタイプ情報の代わりに、基本クラスへの属性として追加する方が良いです。

この属性は、オブジェクトのオブジェクトのタイプを反映し、列挙値にエンコードします。

辞書は、型を列挙された値にマッピングするためにそれ自体で実装する必要があります。

<code class="language-csharp">[JsonConverter(typeof(SubTypeClassConverter))]
public class SubTypeClassBase
{
    [JsonConverter(typeof(StringEnumConverter))]
    public SubType Type { get { return typeToSubType[GetType()]; } }
}</code>
ログイン後にコピー
jsonconverterはdeepenseに使用されます:

typeToSubType

カスタムを作成

メソッドは単独で実装する必要があり、列挙値に従って対応するタイプを返します。

JsonConverter利点:

<code class="language-csharp">public class SubTypeClassConverter : JsonConverter
{
    // 读取 JSON 并确定实际类型
    public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
    {
        var token = JToken.Load(reader);
        var typeToken = token["Type"];
        var actualType = SubTypeClassBase.GetTypeFromSubType(typeToken.ToObject<SubType>(serializer)); // 使用 GetTypeFromSubType 方法
        if (existingValue == null || existingValue.GetType() != actualType)
        {
            // 创建实际的对象实例
            var contract = serializer.ContractResolver.ResolveContract(actualType);
            existingValue = contract.DefaultCreator();
        }
        // 使用 "Populate" 方法避免无限递归
        using (var subReader = token.CreateReader())
        {
            serializer.Populate(subReader, existingValue);
        }
        return existingValue;
    }

    // ...其他方法 (WriteJson 等) ...
}</code>
ログイン後にコピー

コンテナとは無関係に、クラス内の属性にエンコードするGetTypeFromSubTypeサブタイプの情報。

循環化は動的に処理され、クラス構造がシリアル化を損なうことなく将来クラス構造を変更できるようにします。 JSON出力の冗長

フィールドを排除し、そのサイズを縮小します。
  • 注:
  • コードフラグメントにおける
  • および
  • の特定の実装。 $type列挙には、可能なすべてのサブタイプを含める必要があります。
  • 辞書は、各サブクラスのタイプを対応する
列挙値にマッピングする必要があります。

メソッドは逆マッピングを実行する必要があります。

以上が「$type」フィールドを使用せずに、Json.Net でポリモーフィックな子オブジェクトのカスタム シリアル化を実現するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート