Lire en anglais

Partager via


Type.IsSerializable Propriété

Définition

Attention

Formatter-based serialization is obsolete and should not be used.

Obtient une valeur indiquant si est Type sérialisable binaire.

C#
public virtual bool IsSerializable { get; }
C#
[System.Obsolete("Formatter-based serialization is obsolete and should not be used.", DiagnosticId="SYSLIB0050", UrlFormat="https://aka.ms/dotnet-warnings/{0}")]
public virtual bool IsSerializable { get; }
C#
public bool IsSerializable { get; }

Valeur de propriété

true si est Type sérialisable binaire ; sinon, false.

Implémente

Attributs

Exemples

L’exemple suivant crée une instance de MyTestClass classe, définit l’attribut [Serializable] et vérifie la IsSerializable propriété pour true ou false.

C#
using System;
namespace SystemType
{
    public class MyClass
    {
        // Declare a public class with the [Serializable] attribute.
        [Serializable] public class MyTestClass
        {
        }
        public static void Main(string []args)
        {
            try
            {
                bool myBool = false;
                MyTestClass myTestClassInstance = new MyTestClass();
                // Get the type of myTestClassInstance.
                Type myType = myTestClassInstance.GetType();
                // Get the IsSerializable property of myTestClassInstance.
                myBool = myType.IsSerializable;
                Console.WriteLine("\nIs {0} serializable? {1}.", myType.FullName, myBool.ToString());
            }
            catch (Exception e)
            {
                Console.WriteLine("\nAn exception occurred: {0}", e.Message);
            }
        }
    }
}

Remarques

Les types définis dans .NET Standard ne sont pas marqués avec SerializableAttribute. Au lieu de cela, chaque implémentation .NET détermine si un type est sérialisable binaire. Au moment de l’exécution, vous pouvez utiliser la IsSerializable propriété pour déterminer si cette implémentation prend en charge la sérialisation binaire d’un instance du type. Pour plus d’informations et un exemple, consultez Guide pratique pour déterminer si un objet .NET Standard est sérialisable.

Si le actuel Type représente un type générique construit, cette propriété s’applique à la définition de type générique à partir de laquelle le type a été construit. Par exemple, si le actuel Type représente MyGenericType<int> (MyGenericType(Of Integer) en Visual Basic), la valeur de cette propriété est déterminée par MyGenericType<T>.

Si le actuel Type représente un paramètre de type dans la définition d’un type générique ou d’une méthode générique, cette propriété retourne falsetoujours .

S’applique à

Produit Versions (Obsolète)
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7 (8, 9)
.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
.NET Standard 2.0, 2.1

Voir aussi