DataContractSerializer.WriteEndObject Méthode
Définition
Important
Certaines informations portent sur la préversion du produit qui est susceptible d’être en grande partie modifiée avant sa publication. Microsoft exclut toute garantie, expresse ou implicite, concernant les informations fournies ici.
Écrit l’élément XML fermant à l’aide de l’enregistreur spécifié.
Surcharges
| Nom | Description |
|---|---|
| WriteEndObject(XmlDictionaryWriter) |
Écrit l’élément XML fermant à l’aide d’un XmlDictionaryWriter. |
| WriteEndObject(XmlWriter) |
Écrit l’élément XML fermant à l’aide d’un XmlWriter. |
WriteEndObject(XmlDictionaryWriter)
Écrit l’élément XML fermant à l’aide d’un XmlDictionaryWriter.
public:
override void WriteEndObject(System::Xml::XmlDictionaryWriter ^ writer);
public override void WriteEndObject(System.Xml.XmlDictionaryWriter writer);
override this.WriteEndObject : System.Xml.XmlDictionaryWriter -> unit
Public Overrides Sub WriteEndObject (writer As XmlDictionaryWriter)
Paramètres
- writer
- XmlDictionaryWriter
XmlDictionaryWriter Utilisé pour écrire le flux.
Exceptions
Le type sérialisé n’est pas conforme aux règles de contrat de données. Par exemple, l’attribut DataContractAttribute n’a pas été appliqué au type.
Il existe un problème avec l’instance en cours d’écriture.
Exemples
L’exemple suivant crée un objet à sérialiser, une instance du DataContractSerializer, et une instance de la XmlDictionaryWriter classe. L’exemple utilise les méthodes et WriteObjectContentWriteObjectContentles WriteStartObjectméthodes pour écrire les données d’objet dans le document XML. Effectuer ces appels équivaut à effectuer un seul appel de la WriteObject méthode. Par exemple, un utilisateur peut effectuer les appels séparément pour insérer des attributs XML supplémentaires dans le code XML après avoir appelé la WriteStartObject méthode.
public static void WriteObjectContentInDocument(string path)
{
// Create the object to serialize.
Person p = new Person("Lynn", "Tsoflias", 9876);
// Create the writer object.
FileStream fs = new FileStream(path, FileMode.Create);
XmlDictionaryWriter writer =
XmlDictionaryWriter.CreateTextWriter(fs);
DataContractSerializer ser =
new DataContractSerializer(typeof(Person));
// Use the writer to start a document.
writer.WriteStartDocument(true);
// Use the writer to write the root element.
writer.WriteStartElement("Company");
// Use the writer to write an element.
writer.WriteElementString("Name", "Microsoft");
// Use the serializer to write the start,
// content, and end data.
ser.WriteStartObject(writer, p);
ser.WriteObjectContent(writer, p);
ser.WriteEndObject(writer);
// Use the writer to write the end element and
// the end of the document.
writer.WriteEndElement();
writer.WriteEndDocument();
// Close and release the writer resources.
writer.Flush();
fs.Flush();
fs.Close();
}
Public Shared Sub WriteObjectContentInDocument(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 DataContractSerializer(GetType(Person))
' Use the writer to start a document.
writer.WriteStartDocument(True)
' Use the writer to write the root element.
writer.WriteStartElement("Company")
' Use the writer to write an element.
writer.WriteElementString("Name", "Microsoft")
' Use the serializer to write the start,
' content, and end data.
ser.WriteStartObject(writer, p)
ser.WriteObjectContent(writer, p)
ser.WriteEndObject(writer)
' Use the writer to write the end element and
' the end of the document.
writer.WriteEndElement()
writer.WriteEndDocument()
' Close and release the writer resources.
writer.Flush()
fs.Flush()
fs.Close()
End Sub
S’applique à
WriteEndObject(XmlWriter)
Écrit l’élément XML fermant à l’aide d’un XmlWriter.
public:
override void WriteEndObject(System::Xml::XmlWriter ^ writer);
public override void WriteEndObject(System.Xml.XmlWriter writer);
override this.WriteEndObject : System.Xml.XmlWriter -> unit
Public Overrides Sub WriteEndObject (writer As XmlWriter)
Paramètres
Exceptions
Le type sérialisé n’est pas conforme aux règles de contrat de données. Par exemple, l’attribut DataContractAttribute n’a pas été appliqué au type.
Il existe un problème avec l’instance en cours d’écriture.