Evitare attributi non sealed
Aggiornamento: novembre 2007
TypeName |
AvoidUnsealedAttributes |
CheckId |
CA1813 |
Category |
Microsoft.Performance |
Breaking Change |
Breaking |
Causa
Un tipo pubblico eredita da System.Attribute, non è astratto e non è sealed (NotInheritable in Visual Basic).
Descrizione della regola
La libreria di classi .NET Framework fornisce metodi per recuperare attributi personalizzati. Per impostazione predefinita, questi metodi cercano la gerarchia di ereditarietà degli attributi; ad esempio Attribute.GetCustomAttribute cerca il tipo di attributo specificato o qualsiasi tipo di attributo che estenda l'attributo specificato. L'utilizzo di attributi sealed elimina la ricerca tramite la gerarchia di ereditarietà e può migliorare le prestazioni.
Correzione di violazioni
Per correggere una violazione di questa regola, rendere l'attributo sealed o astratto.
Esclusione di avvisi
L'esclusione di un avviso da questa regola è sicura. È opportuno eseguire questa operazione solo se si definisce la gerarchia di un attributo e non è possibile rendere l'attributo sealed o astratto.
Esempio
Nell'esempio riportato di seguito viene illustrato un attributo personalizzato che soddisfa questa regola.
Imports System
Namespace PerformanceLibrary
' Satisfies rule: AvoidUnsealedAttributes.
<AttributeUsage(AttributeTargets.Class Or AttributeTargets.Struct)> _
NotInheritable Public Class DeveloperAttribute
Inherits Attribute
Private nameValue As String
Public Sub New(name As String)
nameValue = name
End Sub
Public ReadOnly Property Name() As String
Get
Return nameValue
End Get
End Property
End Class
End Namespace
using System;
namespace PerformanceLibrary
{
// Satisfies rule: AvoidUnsealedAttributes.
[AttributeUsage(AttributeTargets.Class|AttributeTargets.Struct)]
public sealed class DeveloperAttribute: Attribute
{
private string nameValue;
public DeveloperAttribute(string name)
{
nameValue = name;
}
public string Name
{
get
{
return nameValue;
}
}
}
}
Regole correlate
Definire le funzioni di accesso per gli argomenti degli attributi
Contrassegnare gli attributi con AttributeUsageAttribute