IDataContractSurrogate.GetObjectToSerialize(Object, Type) Methode

Definition

Gibt während der Serialisierung ein Objekt zurück, das das angegebene Objekt ersetzt.

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

Parameter

obj
Object

Das zu ersetzende Objekt.

targetType
Type

Das Type ersetzte Objekt sollte zugewiesen werden.

Gibt zurück

Das ersetzte Objekt, das serialisiert wird. Das Objekt muss von der DataContractSerializer. Beispielsweise muss sie mit dem DataContractAttribute Attribut oder anderen Mechanismen gekennzeichnet werden, die der Serialisierer erkennt.

Beispiele

Das folgende Beispiel zeigt eine Implementierung der GetObjectToSerialize Methode.

public object GetObjectToSerialize(object obj, Type targetType)
{
        Console.WriteLine("GetObjectToSerialize Invoked");
        Console.WriteLine("\t type name: {0}", obj.ToString());
        Console.WriteLine("\t target type: {0}", targetType.Name);
        // This method is called on serialization.
        // If Person is not being serialized...
        if (obj is Person )
        {
            Console.WriteLine("\t returning PersonSurrogated");
            // ... use the XmlSerializer to perform the actual serialization.
            PersonSurrogated  ps = new PersonSurrogated();
            XmlSerializer xs = new XmlSerializer(typeof(Person));
            StringWriter sw = new StringWriter();
            xs.Serialize(sw, (Person)obj );
            ps.xmlData = sw.ToString();
            return ps;
        }
        return obj;
    }
Public Function GetObjectToSerialize(ByVal obj As Object, _
    ByVal targetType As Type) As Object _
    Implements IDataContractSurrogate.GetObjectToSerialize
    Console.WriteLine("GetObjectToSerialize Invoked")
    Console.WriteLine(vbTab & "type name: {0}", obj.ToString)
    Console.WriteLine(vbTab & "target type: {0}", targetType.Name)
    ' This method is called on serialization.
    ' If Person is not being serialized...
    If TypeOf obj Is Person Then
        Console.WriteLine(vbTab & "returning PersonSurrogated")
        ' ... use the XmlSerializer to perform the actual serialization.
        Dim ps As New PersonSurrogated()
        Dim xs As New XmlSerializer(GetType(Person))
        Dim sw As New StringWriter()
        xs.Serialize(sw, CType(obj, Person))
        ps.xmlData = sw.ToString()
        Return ps
    End If
    Return obj

End Function

Hinweise

Diese Methode darf nicht zurückgegeben null werden, da die Daten bei der Deserialisierung in den Typ Object umwandeln und ein InvalidCastException Fehler ausgelöst wird.

Gilt für: