IDataContractSurrogate.GetDeserializedObject(Object, Type) メソッド

定義

逆シリアル化中に、指定したオブジェクトの代わりに使用されるオブジェクトを返します。

public:
 System::Object ^ GetDeserializedObject(System::Object ^ obj, Type ^ targetType);
public object GetDeserializedObject(object obj, Type targetType);
abstract member GetDeserializedObject : obj * Type -> obj
Public Function GetDeserializedObject (obj As Object, targetType As Type) As Object

パラメーター

obj
Object

置き換えられる逆シリアル化されたオブジェクト。

targetType
Type

置換されたオブジェクトを割り当てる必要がある Type

返品

置換された逆シリアル化されたオブジェクト。 このオブジェクトは、 DataContractSerializerによってシリアル化できる型である必要があります。 たとえば、シリアライザーが認識する DataContractAttribute 属性またはその他のメカニズムでマークする必要があります。

次の例は、 GetDeserializedObject メソッドの実装を示しています。

public object GetDeserializedObject(Object obj , Type targetType)
{
    Console.WriteLine("GetDeserializedObject invoked");
    // This method is called on deserialization.
    // If PersonSurrogated is being deserialized...
    if (obj is PersonSurrogated)
        {
            //... use the XmlSerializer to do the actual deserialization.
            PersonSurrogated ps = (PersonSurrogated)obj;
            XmlSerializer xs = new XmlSerializer(typeof(Person));
            return (Person)xs.Deserialize(new StringReader(ps.xmlData));
        }
        return obj;
}
Public Function GetDeserializedObject(ByVal obj As Object, _
    ByVal targetType As Type) As Object Implements _
    IDataContractSurrogate.GetDeserializedObject
    Console.WriteLine("GetDeserializedObject invoked")
    ' This method is called on deserialization.
    ' If PersonSurrogated is being deserialized...
    If TypeOf obj Is PersonSurrogated Then
        Console.WriteLine(vbTab & "returning PersonSurrogated")
        '... use the XmlSerializer to do the actual deserialization.
        Dim ps As PersonSurrogated = CType(obj, PersonSurrogated)
        Dim xs As New XmlSerializer(GetType(Person))
        Return CType(xs.Deserialize(New StringReader(ps.xmlData)), Person)
    End If
    Return obj

End Function

注釈

単純な実装では、if... を使用します。そうしたら。。。else は、 obj 値が代理型であるかどうかをテストする構造体を制御します。 その場合は、必要に応じて変換し、置換されたオブジェクトを返します。 置き換えられるオブジェクトには、新しいインスタンスまたは同じ obj インスタンスを指定できます。

適用対象