CA1307: StringComparison opgeven voor duidelijkheid

Eigenschappen Weergegeven als
Regel-id CA1307
Titel StringComparison opgeven voor duidelijkheid
Categorie Globalisatie
Oplossing is brekend of niet-brekend Niet-brekend
Standaard ingeschakeld in .NET 8 Nee

Oorzaak

Een tekenreeksvergelijkingsbewerking maakt gebruik van een methode-overbelasting die geen parameter instelt StringComparison .

Beschrijving van regel

Veel bewerkingen voor het vergelijken van tekenreeksen bieden een overbelasting die een StringComparison opsommingswaarde als parameter accepteert.

Wanneer een overbelasting bestaat die een StringComparison parameter gebruikt, moet deze worden gebruikt in plaats van een overbelasting die deze parameter niet accepteert. Door deze parameter expliciet in te stellen, wordt uw code vaak duidelijker en eenvoudiger te onderhouden. Zie Tekenreeksvergelijkingen expliciet opgeven voor meer informatie.

Notitie

Met deze regel wordt niet rekening gehouden met de standaardwaarde StringComparison die wordt gebruikt door de vergelijkingsmethode. Daarom kan het mogelijk luidruchtig zijn voor methoden die de Ordinal tekenreeksvergelijking standaard gebruiken en de gebruiker die is bedoeld om deze standaardvergelijkingsmodus te gebruiken. Als u alleen schendingen wilt zien voor bekende tekenreeksmethoden die standaard cultuurspecifieke tekenreeksvergelijking gebruiken, gebruikt u CA1310: Geef stringComparison op voor juistheid .

Schendingen oplossen

Als u een schending van deze regel wilt oplossen, wijzigt u tekenreeksvergelijkingsmethoden in overbelastingen die de StringComparison opsomming als parameter accepteren. Wijzig bijvoorbeeld str1.IndexOf(ch1) in str1.IndexOf(ch1, StringComparison.Ordinal).

Wanneer waarschuwingen onderdrukken

Het is veilig om een waarschuwing van deze regel te onderdrukken wanneer duidelijkheid van intentie niet vereist is. Testcode of niet-lokaliseerbare code is bijvoorbeeld mogelijk niet vereist.

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 CA1307
// The code that's violating the rule is on this line.
#pragma warning restore CA1307

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.CA1307.severity = none

Zie Codeanalysewaarschuwingen onderdrukken voor meer informatie.

Zie ook