Sdílet prostřednictvím


CA1813: Vyhněte se nezapečetěným atributům

Vlastnost Hodnota
ID pravidla CA1813
Název Vyhněte se nezapečetěným atributům
Kategorie Výkon
Oprava způsobující chybu nebo chybu způsobující chybu Narušující
Povoleno ve výchozím nastavení v .NET 8 No

Příčina

Veřejný typ dědí z System.Attribute, není abstraktní a není zapečetěn (NotInheritable v jazyce Visual Basic).

Popis pravidla

.NET poskytuje metody pro načítání vlastních atributů. Ve výchozím nastavení tyto metody prohledávají hierarchii dědičnosti atributů. Například System.Attribute.GetCustomAttribute vyhledá zadaný typ atributu nebo jakýkoli typ atributu, který rozšiřuje zadaný typ atributu. Zapečetění atributu eliminuje hledání prostřednictvím hierarchie dědičnosti a může zlepšit výkon.

Jak opravit porušení

Chcete-li opravit porušení tohoto pravidla, zapečetěte typ atributu nebo ho nastavte jako abstraktní.

Kdy potlačit upozornění

Je bezpečné potlačit upozornění z tohoto pravidla. Potlačit pouze v případě, že definujete hierarchii atributů a nemůžete zapečetit atribut nebo ho nastavit jako abstraktní.

Potlačení upozornění

Pokud chcete pouze potlačit jedno porušení, přidejte do zdrojového souboru direktivy preprocesoru, abyste pravidlo zakázali a znovu povolili.

#pragma warning disable CA1813
// The code that's violating the rule is on this line.
#pragma warning restore CA1813

Pokud chcete pravidlo pro soubor, složku nebo projekt zakázat, nastavte jeho závažnost v none konfiguračním souboru.

[*.{cs,vb}]
dotnet_diagnostic.CA1813.severity = none

Další informace naleznete v tématu Jak potlačit upozornění analýzy kódu.

Příklad

Následující příklad ukazuje vlastní atribut, který splňuje toto pravidlo.

// 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;
        }
    }
}
Imports System

Namespace ca1813

    ' Satisfies rule: AvoidUnsealedAttributes.
    <AttributeUsage(AttributeTargets.Class Or AttributeTargets.Struct)>
    Public NotInheritable Class DeveloperAttribute
        Inherits Attribute

        Public Sub New(name As String)
            Me.Name = name
        End Sub


        Public ReadOnly Property Name() As String
    End Class

End Namespace

Viz také