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 |
Überblick
Diese Regel empfiehlt die Verwendung der System.HashCode.Combine-Methode, um einen Hashcode zu berechnen, anstatt benutzerdefinierte Hashcodeberechnungslogik zu verwenden.
Optionen
Diese Regel enthält keine zugehörigen Codeformatoptionen.
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 Konfigurationsdateiauf none
fest.
[*.{cs,vb}]
dotnet_diagnostic.IDE0070.severity = none
Um alle Regeln im Code-Stil zu deaktivieren, setzen Sie den Schweregrad für die Kategorie in der KonfigurationsdateiStyle
auf none
.
[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Style.severity = none
Weitere Informationen finden Sie unter So unterdrücken Sie Codeanalysewarnungen.