NetDataContractSerializer.WriteStartObject Método

Definição

Escreve o elemento XML de abertura usando o escritor especificado.

Sobrecargas

Name Description
WriteStartObject(XmlDictionaryWriter, Object)

Escreve o elemento XML de abertura usando um XmlDictionaryWriterelemento .

WriteStartObject(XmlWriter, Object)

Escreve o elemento XML de abertura usando um XmlWriterelemento .

WriteStartObject(XmlDictionaryWriter, Object)

Escreve o elemento XML de abertura usando um XmlDictionaryWriterelemento .

public:
 override void WriteStartObject(System::Xml::XmlDictionaryWriter ^ writer, System::Object ^ graph);
public override void WriteStartObject(System.Xml.XmlDictionaryWriter writer, object graph);
override this.WriteStartObject : System.Xml.XmlDictionaryWriter * obj -> unit
Public Overrides Sub WriteStartObject (writer As XmlDictionaryWriter, graph As Object)

Parâmetros

writer
XmlDictionaryWriter

Eles XmlDictionaryWriter são usados para escrever o elemento XML.

graph
Object

O objetivo a serializar. Todos os objetos filhos deste objeto raiz são automaticamente serializados.

Exceções

O tipo que está a ser serializado não cumpre as regras dos contratos de dados. Por exemplo, o DataContractAttribute atributo não foi aplicado ao tipo.

Há um problema com a instância ser serializada.

o número máximo de objetos a serializar foi ultrapassado. Verifique a propriedade MaxItemsInObjectGraph.

Exemplos

O exemplo seguinte cria um objeto para serializar, uma instância do NetDataContractSerializer, e uma instância da XmlDictionaryWriter classe. O exemplo utiliza os WriteStartObjectmétodos , WriteObjectContent, e WriteEndObject para escrever os dados do objeto no documento XML.

public sealed class ShowWriteStartObject
{

    public static void WriteObjectData(string path)
    {
        // Create the object to serialize.
        Person p = new Person("Lynn", "Tsoflias", 9876);

        // Create the writer.
        FileStream fs = new FileStream(path, FileMode.Create);
        XmlDictionaryWriter writer =
            XmlDictionaryWriter.CreateTextWriter(fs);

        NetDataContractSerializer ser =
            new NetDataContractSerializer();

        // Use the writer to start a document.
        writer.WriteStartDocument(true);

        // Use the serializer to write the start of the
        // object data. Use it again to write the object
        // data.
        ser.WriteStartObject(writer, p);
        ser.WriteObjectContent(writer, p);

        // Use the serializer to write the end of the
        // object data. Then use the writer to write the end
        // of the document.
        ser.WriteEndObject(writer);
        writer.WriteEndDocument();

        Console.WriteLine("Done");

        // Close and release the writer resources.
        writer.Flush();
        fs.Flush();
        fs.Close();
    }
NotInheritable Public Class ShowWriteStartObject
     
    Public Shared Sub WriteObjectData(ByVal path As String) 
        ' Create the object to serialize.
        Dim p As New Person("Lynn", "Tsoflias", 9876)
        
        ' Create the writer.
        Dim fs As New FileStream(path, FileMode.Create)
        Dim writer As XmlDictionaryWriter = XmlDictionaryWriter.CreateTextWriter(fs)
        
        Dim ser As New System.Runtime.Serialization.NetDataContractSerializer()        

        ' Use the writer to start a document.
        writer.WriteStartDocument(True)
        
        ' Use the serializer to write the start of the 
        ' object data. Use it again to write the object
        ' data. 
        ser.WriteStartObject(writer, p)
        writer.WriteStartAttribute("MyAttribute")
        writer.WriteString("My Text")
        writer.WriteEndAttribute()

        ser.WriteObjectContent(writer, p)
                
        ' Use the serializer to write the end of the 
        ' object data. Then use the writer to write the end
        ' of the document.
        ser.WriteEndObject(writer)
        writer.WriteEndDocument()
        
        Console.WriteLine("Done")
        
        ' Close and release the writer resources.
        writer.Flush()
        fs.Flush()
        fs.Close()
    
    End Sub

Aplica-se a

WriteStartObject(XmlWriter, Object)

Escreve o elemento XML de abertura usando um XmlWriterelemento .

public:
 override void WriteStartObject(System::Xml::XmlWriter ^ writer, System::Object ^ graph);
public override void WriteStartObject(System.Xml.XmlWriter writer, object graph);
override this.WriteStartObject : System.Xml.XmlWriter * obj -> unit
Public Overrides Sub WriteStartObject (writer As XmlWriter, graph As Object)

Parâmetros

writer
XmlWriter

Eles XmlDictionaryWriter são usados para escrever o elemento XML.

graph
Object

O objetivo a serializar. Todos os objetos filhos deste objeto raiz são automaticamente serializados.

Exceções

O tipo que está a ser serializado não cumpre as regras dos contratos de dados. Por exemplo, o DataContractAttribute atributo não foi aplicado ao tipo.

Há um problema com a instância ser serializada.

o número máximo de objetos a serializar foi ultrapassado. Verifique a propriedade MaxItemsInObjectGraph.

Aplica-se a