Ler em inglês

Partilhar via


ObsoleteAttribute Classe

Definição

Marca os elementos do programa que não estão mais em uso. Essa classe não pode ser herdada.

[System.AttributeUsage(System.AttributeTargets.Class | System.AttributeTargets.Constructor | System.AttributeTargets.Delegate | System.AttributeTargets.Enum | System.AttributeTargets.Event | System.AttributeTargets.Field | System.AttributeTargets.Interface | System.AttributeTargets.Method | System.AttributeTargets.Property | System.AttributeTargets.Struct, Inherited=false)]
public sealed class ObsoleteAttribute : Attribute
[System.AttributeUsage(System.AttributeTargets.Class | System.AttributeTargets.Constructor | System.AttributeTargets.Delegate | System.AttributeTargets.Enum | System.AttributeTargets.Event | System.AttributeTargets.Field | System.AttributeTargets.Interface | System.AttributeTargets.Method | System.AttributeTargets.Property | System.AttributeTargets.Struct, Inherited=false)]
[System.Serializable]
public sealed class ObsoleteAttribute : Attribute
[System.AttributeUsage(System.AttributeTargets.Class | System.AttributeTargets.Constructor | System.AttributeTargets.Delegate | System.AttributeTargets.Enum | System.AttributeTargets.Event | System.AttributeTargets.Field | System.AttributeTargets.Interface | System.AttributeTargets.Method | System.AttributeTargets.Property | System.AttributeTargets.Struct, Inherited=false)]
[System.Serializable]
[System.Runtime.InteropServices.ComVisible(true)]
public sealed class ObsoleteAttribute : Attribute
Herança
ObsoleteAttribute
Atributos

Exemplos

O exemplo a seguir define uma classe que contém uma propriedade e um método marcados com o ObsoleteAttribute atributo . Acessar o valor da OldProperty propriedade no código gera um aviso do compilador, mas chamar o CallOldMethod método gera um erro do compilador. O exemplo também mostra a saída que resulta quando você tenta compilar o código-fonte.

using System;
using System.Reflection;

public class Example
{
   // Mark OldProperty As Obsolete.
   [ObsoleteAttribute("This property is obsolete. Use NewProperty instead.", false)]
   public static string OldProperty
   { get { return "The old property value."; } }

   public static string NewProperty
   { get { return "The new property value."; } }

   // Mark CallOldMethod As Obsolete.
   [ObsoleteAttribute("This method is obsolete. Call CallNewMethod instead.", true)]
   public static string CallOldMethod()
   {
      return "You have called CallOldMethod.";
   }

   public static string CallNewMethod()
   {
      return "You have called CallNewMethod.";
   }

   public static void Main()
   {
      Console.WriteLine(OldProperty);
      Console.WriteLine();
      Console.WriteLine(CallOldMethod());
   }
}
// The attempt to compile this example produces output like the following output:
//    Example.cs(31,25): error CS0619: 'Example.CallOldMethod()' is obsolete:
//            'This method is obsolete. Call CallNewMethod instead.'
//    Example.cs(29,25): warning CS0618: 'Example.OldProperty' is obsolete:
//            'This property is obsolete. Use NewProperty instead.'

Comentários

ObsoleteAttribute é aplicável a todos os elementos do programa, exceto assemblies, módulos, parâmetros e valores retornados. Marcar um elemento como obsoleto informa aos usuários que o elemento pode ser removido em uma versão futura do produto.

A cadeia de caracteres atribuída à Message propriedade é emitida pelo compilador quando o destino do atributo é usado no código. O ideal é que a cadeia de caracteres forneça alguma alternativa alternativa ou programática.

Use a IsError propriedade para indicar ao compilador se usar o ObsoleteAttribute atributo deve fazer com que ele emita um erro (IsError é true) ou um aviso (IsError é false).

Para obter mais informações sobre como usar atributos, consulte Atributos.

Construtores

ObsoleteAttribute()

Inicializa uma nova instância da classe ObsoleteAttribute com propriedades padrão.

ObsoleteAttribute(String)

Inicializa uma nova instância da classe ObsoleteAttribute com uma mensagem de solução alternativa especificada.

ObsoleteAttribute(String, Boolean)

Inicializa uma nova instância da classe ObsoleteAttribute com uma mensagem de solução alternativa e um valor booliano indicando se o uso do elemento obsoleto é considerado um erro.

Propriedades

DiagnosticId

Obtém ou define a ID que o compilador usará ao relatar um uso da API.

IsError

Obtém um valor que indica se o compilador tratará o uso de elementos obsoletos do programa como um erro.

Message

Obtém a mensagem alternativa.

TypeId

Quando implementado em uma classe derivada, obtém um identificador exclusivo para este Attribute.

(Herdado de Attribute)
UrlFormat

Obtém ou define a URL da documentação correspondente. A API aceita uma cadeia de caracteres de formato em vez de uma URL real, criando uma URL genérica que inclui a ID de diagnóstico.

Métodos

Equals(Object)

Retorna um valor que indica se essa instância é igual a um objeto especificado.

(Herdado de Attribute)
GetHashCode()

Retorna o código hash para a instância.

(Herdado de Attribute)
GetType()

Obtém o Type da instância atual.

(Herdado de Object)
IsDefaultAttribute()

Quando substituído em uma classe derivada, indica se o valor dessa instância é o valor padrão para a classe derivada.

(Herdado de Attribute)
Match(Object)

Quando substituído em uma classe derivada, retorna um valor que indica se essa instância é igual a um objeto especificado.

(Herdado de Attribute)
MemberwiseClone()

Cria uma cópia superficial do Object atual.

(Herdado de Object)
ToString()

Retorna uma cadeia de caracteres que representa o objeto atual.

(Herdado de Object)

Implantações explícitas de interface

_Attribute.GetIDsOfNames(Guid, IntPtr, UInt32, UInt32, IntPtr)

Mapeia um conjunto de nomes para um conjunto correspondente de identificadores de expedição.

(Herdado de Attribute)
_Attribute.GetTypeInfo(UInt32, UInt32, IntPtr)

Recupera as informações de tipo para um objeto, que pode ser usado para obter as informações de tipo para uma interface.

(Herdado de Attribute)
_Attribute.GetTypeInfoCount(UInt32)

Retorna o número de interfaces de informações do tipo que um objeto fornece (0 ou 1).

(Herdado de Attribute)
_Attribute.Invoke(UInt32, Guid, UInt32, Int16, IntPtr, IntPtr, IntPtr, IntPtr)

Fornece acesso a propriedades e métodos expostos por um objeto.

(Herdado de Attribute)

Aplica-se a

Produto Versões
.NET Core 1.0, Core 1.1, 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 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Confira também