SoapFormatter.Serialize Méthode

Définition

Sérialise un objet ou un graphique d'objets connectés.

Surcharges

Serialize(Stream, Object)

Sérialise un objet ou un graphique d'objets avec la racine spécifiée vers le Stream donné.

Serialize(Stream, Object, Header[])

Sérialise un objet ou graphique d'objets avec la racine spécifiée vers le Stream donné dans le format d'appel de procédure distante SOAP.

Serialize(Stream, Object)

Sérialise un objet ou un graphique d'objets avec la racine spécifiée vers le Stream donné.

C#
public void Serialize (System.IO.Stream serializationStream, object graph);

Paramètres

serializationStream
Stream

Flux sur lequel le formateur place les données à sérialiser.

graph
Object

Objet, ou racine du graphique d'objets, à sérialiser. Tous les objets enfants de cet objet racine sont automatiquement sérialisés.

Implémente

Exceptions

serializationStream a la valeur null.

Exemples

C#
using System;
using System.IO;
using System.Collections;
using System.Runtime.Serialization;

// Note: When building this code, you must reference the
// System.Runtime.Serialization.Formatters.Soap.dll assembly.
using System.Runtime.Serialization.Formatters.Soap;

class App
{
    [STAThread]
    static void Main()
    {
        Serialize();
        Deserialize();
    }

    static void Serialize()
    {
        // Create a hashtable of values that will eventually be serialized.
        Hashtable addresses = new Hashtable();
        addresses.Add("Jeff", "123 Main Street, Redmond, WA 98052");
        addresses.Add("Fred", "987 Pine Road, Phila., PA 19116");
        addresses.Add("Mary", "PO Box 112233, Palo Alto, CA 94301");

        // To serialize the hashtable (and its key/value pairs),
        // you must first open a stream for writing.
        // Use a file stream here.
        FileStream fs = new FileStream("DataFile.soap", FileMode.Create);

        // Construct a SoapFormatter and use it
        // to serialize the data to the stream.
        SoapFormatter formatter = new SoapFormatter();
        try
        {
            formatter.Serialize(fs, addresses);
        }
        catch (SerializationException e)
        {
            Console.WriteLine("Failed to serialize. Reason: " + e.Message);
            throw;
        }
        finally
        {
            fs.Close();
        }
    }

    static void Deserialize()
    {
        // Declare the hashtable reference.
        Hashtable addresses  = null;

        // Open the file containing the data that you want to deserialize.
        FileStream fs = new FileStream("DataFile.soap", FileMode.Open);
        try
        {
            SoapFormatter formatter = new SoapFormatter();

            // Deserialize the hashtable from the file and
            // assign the reference to the local variable.
            addresses = (Hashtable) formatter.Deserialize(fs);
        }
        catch (SerializationException e)
        {
            Console.WriteLine("Failed to deserialize. Reason: " + e.Message);
            throw;
        }
        finally
        {
            fs.Close();
        }

        // To prove that the table deserialized correctly,
        // display the key/value pairs to the console.
        foreach (DictionaryEntry de in addresses)
        {
            Console.WriteLine("{0} lives at {1}.", de.Key, de.Value);
        }
    }
}

Remarques

Les objets TimeSpan sont sérialisés selon la norme ISO 8601 : 1998 section 5.5.3.2.1 « Alternative ».

S’applique à

.NET Framework 4.8.1 et autres versions
Produit Versions
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1

Serialize(Stream, Object, Header[])

Sérialise un objet ou graphique d'objets avec la racine spécifiée vers le Stream donné dans le format d'appel de procédure distante SOAP.

C#
public void Serialize (System.IO.Stream serializationStream, object graph, System.Runtime.Remoting.Messaging.Header[] headers);

Paramètres

serializationStream
Stream

Flux sur lequel le formateur place les données à sérialiser.

graph
Object

Objet ou racine du graphique d'objets à sérialiser. Tous les objets enfants de cet objet racine sont automatiquement sérialisés.

headers
Header[]

En-têtes de communication à distance à inclure dans la sérialisation. Peut être null.

Implémente

Exceptions

serializationStream a la valeur null.

Remarques

Les en-têtes sont utilisés uniquement pour des applications de communication à distance spécifiques.

Les objets TimeSpan sont sérialisés selon la norme ISO 8601 : 1998 section 5.5.3.2.1 « Alternative ».

S’applique à

.NET Framework 4.8.1 et autres versions
Produit Versions
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1