Udostępnij za pośrednictwem


CA2265: Nie należy porównywać Span<T> z null lub default

Właściwości Wartość
Identyfikator reguły CA2264
Tytuł Nie porównuje Span<T> się z null lub default
Kategoria Użycie
Poprawka powodująca niezgodność lub niezgodność Niezgodność
Domyślnie włączone na platformie .NET 9 Jako ostrzeżenie

Przyczyna

Wystąpienie Span<T> jest porównywane z null defaultlub .

Opis reguły

Porównywanie zakresu z null lub default może nie robić tego, co zamierzasz. defaultnull literał jest niejawnie konwertowany na Span<T>.Empty.

Jak naprawić naruszenia

Usuń nadmiarowe porównanie lub utwórz kod bardziej jawnie, wywołując IsEmpty zamiast tego.

Przykład

Poniższy fragment kodu przedstawia dwa naruszenia ca2265 i poprawkę dla naruszeń.

Span<int> span = new([1, 2, 3]);
// CA2265 violation.
if (span == null) { }
// CA2265 violation.
if (span == default) { }

// Fixes the violation.
if (span.IsEmpty) { }

Kiedy pomijać ostrzeżenia

Jeśli chcesz porównać zakres z pustym zakresem, można bezpiecznie pominąć to ostrzeżenie.

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 CA2265
// The code that's violating the rule is on this line.
#pragma warning restore CA2265

Aby wyłączyć regułę dla pliku, folderu lub projektu, ustaw jego ważność na none w pliku konfiguracji.

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

Aby uzyskać więcej informacji, zobacz Jak pominąć ostrzeżenia dotyczące analizy kodu.

Zobacz też