Nuta
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować się zalogować lub zmienić katalog.
Dostęp do tej strony wymaga autoryzacji. Możesz spróbować zmienić katalogi.
CA2265: Nie należy porównywać
| 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 10 | Jako ostrzeżenie |
Przyczyna
Wystąpienie Span<T> jest porównywane z nulldefaultlub .
Opis reguły
Porównywanie zakresu z null lub default może nie robić tego, co zamierzasz.
default
null 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.