Share via


CA2211: Niet-constante velden mogen niet zichtbaar zijn

Eigenschappen Weergegeven als
Regel-id CA2211
Titel Niet-constante velden mogen niet zichtbaar zijn
Categorie Gebruik
Oplossing is brekend of niet-brekend Breken
Standaard ingeschakeld in .NET 9 Als suggestie

Oorzaak

Een openbaar of beveiligd statisch veld is niet constant en is niet alleen-lezen.

Beschrijving van regel

Statische velden die geen constanten of alleen-lezen zijn, zijn niet thread-veilig. Toegang tot een dergelijk veld moet zorgvuldig worden beheerd en vereist geavanceerde programmeertechnieken voor het synchroniseren van de toegang tot het klasseobject. Omdat dit moeilijke vaardigheden zijn om te leren en een dergelijk object te testen een eigen uitdaging vormt, kunnen statische velden het beste worden gebruikt om gegevens op te slaan die niet veranderen. Deze regel is van toepassing op bibliotheken; toepassingen mogen geen velden beschikbaar maken.

Schendingen oplossen

Als u een schending van deze regel wilt oplossen, moet u het statische veld constant of alleen-lezen maken. Als dit niet mogelijk is, ontwerpt u het type opnieuw om een alternatief mechanisme te gebruiken, zoals een thread-veilige eigenschap waarmee de toegang tot het onderliggende veld wordt beheerd. Realiseer u dat problemen zoals vergrendelingsconflicten en impasses van invloed kunnen zijn op de prestaties en het gedrag van de bibliotheek.

Wanneer waarschuwingen onderdrukken

Het is veilig om een waarschuwing van deze regel te onderdrukken als u een toepassing ontwikkelt en daarom volledige controle hebt over de toegang tot het type dat het statische veld bevat. Bibliotheekontwerpers mogen geen waarschuwing van deze regel onderdrukken; het gebruik van niet-constante statische velden kan het lastig maken om de bibliotheek goed te gebruiken voor ontwikkelaars.

Een waarschuwing onderdrukken

Als u slechts één schending wilt onderdrukken, voegt u preprocessorrichtlijnen toe aan uw bronbestand om de regel uit te schakelen en vervolgens opnieuw in te schakelen.

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

Als u de regel voor een bestand, map of project wilt uitschakelen, stelt u de ernst none ervan in op het configuratiebestand.

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

Zie Codeanalysewaarschuwingen onderdrukken voor meer informatie.

Opmerking

In het volgende voorbeeld ziet u een type dat deze regel schendt.


Imports System

Namespace ca2211

    Public Class SomeStaticFields
        ' Violates rule: AvoidNonConstantStatic;
        ' the field is public and not a literal.
        Public Shared publicField As DateTime = DateTime.Now

        ' Satisfies rule: AvoidNonConstantStatic.
        Public Shared ReadOnly literalField As DateTime = DateTime.Now

        ' Satisfies rule: NonConstantFieldsShouldNotBeVisible;
        ' the field is private.
        Private Shared privateField As DateTime = DateTime.Now
    End Class
End Namespace
public class SomeStaticFields
{
    // Violates rule: AvoidNonConstantStatic;
    // the field is public and not a literal.
    static public DateTime publicField = DateTime.Now;

    // Satisfies rule: AvoidNonConstantStatic.
    public static readonly DateTime literalField = DateTime.Now;

    // Satisfies rule: NonConstantFieldsShouldNotBeVisible;
    // the field is private.
    static DateTime privateField = DateTime.Now;
}