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. |
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ć.
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.
Aby naprawić naruszenie tej reguły, podaj implementację elementu Equals. Jeśli to możliwe, zaimplementuj operator równości.
Można bezpiecznie pominąć ostrzeżenie z tej reguły, jeśli wystąpienia typu wartości nie będą porównywane ze sobą.
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.
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.
Możesz skonfigurować, które części bazy kodu mają być uruchamiane na podstawie ich ułatwień dostępu, ustawiając opcję api_surface. 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
Uwaga
Zastąp część XXXX
CAXXXX
identyfikatorem odpowiedniej reguły.
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);
}
}
Opinia o produkcie .NET
.NET to projekt typu open source. Wybierz link, aby przekazać opinię: