Freigeben über


CA1870: Verwenden einer zwischengespeicherten „SearchValues“-Instanz

Eigenschaft Wert
Regel-ID CA1870
Titel Verwenden einer zwischengespeicherten „SearchValues“-Instanz
Kategorie Leistung
Fix führt oder führt nicht zur Unterbrechung Nicht unterbrechend
Standardmäßig in .NET 9 aktiviert Als Vorschlag

Ursache

Eine IndexOfAny- oder ContainsAny-Methode wird mit vielen konstanten Werten aufgerufen, die stattdessen von der Verwendung von SearchValues profitieren können.

Die Regel kennzeichnet keine Aufrufe, die bis zu fünf Werte verwenden, da diese bereits eine optimale Implementierung verwenden.

Regelbeschreibung

Die Verwendung einer zwischengespeicherten SearchValues<T>-Instanz ist effizienter als das direkte Übergeben von Werten an IndexOfAny oder ContainsAny.

Behandeln von Verstößen

Erstellen und zwischenspeichern Sie eine SearchValues<T>-Instanz in einem static readonly-Feld, und übergeben Sie diese Instanz stattdessen an den IndexOfAny- oder ContainsAny-Aufruf.

Eine Codekorrektur, die diese Transformation automatisch ausführt, ist verfügbar.

Beispiel

Der folgende Codeausschnitt zeigt zwei Verstöße gegen CA1870:

static readonly char[] MyValues = new[] { 'a', 'b', 'c', 'x', 'y', 'z' };

static int IndexOfMyValues(ReadOnlySpan<char> text)
{
    return text.IndexOfAny(MyValues);
}

static bool ContainsOnlyMyValues(ReadOnlySpan<char> text)
{
    return !text.ContainsAnyExcept("abcxyz");
}

Der folgende Codeschnipsel korrigiert die Verletzung:

private static readonly SearchValues<char> s_myValues = SearchValues.Create("abcxyz");

static int IndexOfMyValues(ReadOnlySpan<char> text)
{
    return text.IndexOfAny(s_myValues);
}

static bool ContainsOnlyMyValues(ReadOnlySpan<char> text)
{
    return !text.ContainsAnyExcept(s_myValues);
}

Bei mehreren Aufrufen von IndexOfAny mit demselben Wertesatz sollte s_myValues wiederverwendet werden.

Wann sollten Warnungen unterdrückt werden?

Es ist ungefährlich, diese Warnung zu unterdrücken, wenn die Leistung kein Problem ist.

Unterdrücken einer Warnung

Um nur eine einzelne Verletzung zu unterdrücken, fügen Sie der Quelldatei Präprozessoranweisungen hinzu, um die Regel zu deaktivieren und dann wieder zu aktivieren.

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

Um die Regel für eine Datei, einen Ordner oder ein Projekt zu deaktivieren, legen Sie den Schweregrad in der none auf fest.

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

Weitere Informationen finden Sie unter Vorgehensweise: Unterdrücken von Codeanalyse-Warnungen.