CA1815: Przesłoń metodę equals i operator równości dla typów wartości
Właściwości | Wartość |
---|---|
Identyfikator reguły | CA1815 |
Tytuł | Przesłaniaj metodę equals i operator równości w typach wartości |
Kategoria | Wydajność |
Poprawka powodująca niezgodność lub niezgodność | Niezgodność |
Domyślnie włączone na platformie .NET 9 | Nie. |
Przyczyna
Typ wartości nie System.Object.Equals zastępuje ani nie implementuje operatora równości (==). Ta reguła nie sprawdza wyliczenia.
Domyślnie ta reguła analizuje tylko typy widoczne zewnętrznie, ale można to skonfigurować.
Opis reguły
W przypadku typów wartości nieblitarnych dziedziczona implementacja Equals używa System.Reflection biblioteki do porównywania zawartości wszystkich pól. Odbicie jest obliczeniowo kosztowne, a porównanie równości każdego pola może być niepotrzebne. Jeśli oczekujesz, że użytkownicy będą porównywać lub sortować wystąpienia lub używać ich jako kluczy tabeli skrótów, typ wartości powinien implementować wartość Equals. Jeśli język programowania obsługuje przeciążenie operatorów, należy również zapewnić implementację operatorów równości i nierówności.
Jak naprawić naruszenia
Aby naprawić naruszenie tej reguły, podaj implementację elementu Equals. Jeśli to możliwe, zaimplementuj operator równości.
Kiedy pomijać ostrzeżenia
Można bezpiecznie pominąć ostrzeżenie z tej reguły, jeśli wystąpienia typu wartości nie będą porównywane ze sobą.
Pomijanie ostrzeżenia
Jeśli chcesz po prostu pominąć pojedyncze naruszenie, dodaj dyrektywy preprocesora do pliku źródłowego, aby wyłączyć, a następnie ponownie włączyć regułę.
#pragma warning disable CA1815
// The code that's violating the rule is on this line.
#pragma warning restore CA1815
Aby wyłączyć regułę dla pliku, folderu lub projektu, ustaw jego ważność na none
w pliku konfiguracji.
[*.{cs,vb}]
dotnet_diagnostic.CA1815.severity = none
Aby uzyskać więcej informacji, zobacz Jak pominąć ostrzeżenia dotyczące analizy kodu.
Konfigurowanie kodu do analizowania
Użyj następującej opcji, aby skonfigurować, które części bazy kodu mają być uruchamiane w tej regule.
Tę opcję można skonfigurować tylko dla tej reguły, dla wszystkich reguł, do których ma ona zastosowanie, lub dla wszystkich reguł w tej kategorii (wydajność), których dotyczy. Aby uzyskać więcej informacji, zobacz Opcje konfiguracji reguły jakości kodu.
Uwzględnij określone powierzchnie interfejsu API
Możesz skonfigurować, na których częściach bazy kodu ma być uruchamiana ta reguła, na podstawie ich ułatwień dostępu. Aby na przykład określić, że reguła powinna być uruchamiana tylko na powierzchni niepublicznego interfejsu API, dodaj następującą parę klucz-wartość do pliku editorconfig w projekcie:
dotnet_code_quality.CAXXXX.api_surface = private, internal
Nuta
Zastąp część XXXX
CAXXXX
identyfikatorem odpowiedniej reguły.
Przykład
Poniższy kod przedstawia strukturę (typ wartości), która narusza tę regułę:
// Violates this rule
public struct Point
{
public Point(int x, int y)
{
X = x;
Y = y;
}
public int X { get; }
public int Y { get; }
}
Poniższy kod naprawia poprzednie naruszenie, przesłaniając i implementując System.ValueType.Equals operatory równości (==
i !=
):
public struct Point : IEquatable<Point>
{
public Point(int x, int y)
{
X = x;
Y = y;
}
public int X { get; }
public int Y { get; }
public override int GetHashCode()
{
return X ^ Y;
}
public override bool Equals(object? obj)
{
if (!(obj is Point))
return false;
return Equals((Point)obj);
}
public bool Equals(Point other)
{
if (X != other.X)
return false;
return Y == other.Y;
}
public static bool operator ==(Point point1, Point point2)
{
return point1.Equals(point2);
}
public static bool operator !=(Point point1, Point point2)
{
return !point1.Equals(point2);
}
}
Powiązane reguły
- CA2231: Przeciążaj operator równości w przypadku przesłaniania metody ValueType.Equals
- CA2226: Operatory powinny mieć symetryczne przeciążenia