Freigeben über


Verwenden von "System.HashCode.Combine" (IDE0070)

Eigentum Wert
Regel-ID IDE0070
Titel Verwenden Sie System.HashCode.Combine
Kategorie Stil
Unterkategorie Sprachregeln (Präferenzen auf Ausdrucksebene)
Anwendbare Sprachen C# und Visual Basic
Options dotnet_prefer_system_hash_code

Überblick

Diese Regel empfiehlt die Verwendung der System.HashCode.Combine-Methode, um einen Hashcode zu berechnen, anstatt benutzerdefinierte Hashcodeberechnungslogik zu verwenden.

Optionen

Optionen geben das Verhalten an, das die Regel erzwingen soll. Informationen zum Konfigurieren von Optionen finden Sie unter Optionsformat.

dotnet_prefer_system_hash_code

Eigentum Wert Beschreibung
Name der Option dotnet_prefer_system_hash_code
Optionswerte true Bevorzugen Sie die Verwendung System.HashCode.Combine für die Hashcodeberechnung.
false Verzichten Sie darauf, System.HashCode.Combine für die Berechnung des Hash-Codes zu verwenden.
Standardwert der Option true

Beispiel

class B
{
    public override int GetHashCode() => 0;
}

class C : B
{
    int j;

    // Code with violations
    public override int GetHashCode()
    {
        // IDE0070: GetHashCode can be simplified.
        var hashCode = 339610899;
        hashCode = hashCode * -1521134295 + base.GetHashCode();
        hashCode = hashCode * -1521134295 + j.GetHashCode();
        return hashCode;
    }

    // Fixed code
    public override int GetHashCode()
    {
        return System.HashCode.Combine(base.GetHashCode(), j);
    }
}

Unterdrücken einer Warnung

Wenn Sie nur einen einzelnen Verstoß unterdrücken möchten, fügen Sie Ihrer Quelldatei Präprozessordirektiven hinzu, um die Regel zu deaktivieren und dann erneut zu aktivieren.

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

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

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

Um alle Code-Stil-Regeln zu deaktivieren, setzen Sie den Schweregrad der Kategorie Style auf none im Konfigurationsdatei.

[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Style.severity = none

Weitere Informationen finden Sie unter So unterdrücken Sie Codeanalysewarnungen.

Siehe auch