Stosuj propagację wartości null (IDE0031)
Własność | Wartość |
---|---|
identyfikator reguły | IDE0031 |
Tytuł | Użyj propagacji null |
Kategoria | Styl |
podkategorii | Reguły języka (preferencje na poziomie wyrażenia) |
stosowane języki | C# i Visual Basic |
opcje | dotnet_style_null_propagation |
Przegląd
Ta reguła stylu dotyczy użycia operatora warunkowego o wartości null w porównaniu z ternary wyrażenie warunkowe z sprawdzaniem wartości null.
Opcje
Ustaw wartość skojarzonej opcji, aby określić, czy mają być używane operatory warunkowe sprawdzające wartość null, czy też trójargumentowe wyrażenia warunkowe z kontrolą wartości null.
Aby uzyskać więcej informacji na temat konfigurowania opcji, zobacz Format opcji.
dotnet_style_null_propagation
Własność | Wartość | Opis |
---|---|---|
nazwa opcji | dotnet_style_null_propagation | |
wartości opcji | true |
Preferuj używanie operatora warunkowego o wartości null, jeśli jest to możliwe |
false |
Lepiej używać ternarnego sprawdzania wartości null, jeśli jest to możliwe | |
domyślna wartość opcji | true |
// dotnet_style_null_propagation = true
var v = o?.ToString();
// dotnet_style_null_propagation = false
var v = o == null ? null : o.ToString(); // or
var v = o != null ? o.ToString() : null;
' dotnet_style_null_propagation = true
Dim v = o?.ToString()
' dotnet_style_null_propagation = false
Dim v = If(o Is Nothing, Nothing, o.ToString()) ' or
Dim v = If(o IsNot Nothing, o.ToString(), Nothing)
Pomijanie ostrzeżenia
Jeśli chcesz pominąć tylko jedno naruszenie, dodaj dyrektywy preprocesora do pliku źródłowego, aby wyłączyć, a następnie ponownie włączyć regułę.
#pragma warning disable IDE0031
// The code that's violating the rule is on this line.
#pragma warning restore IDE0031
Aby wyłączyć regułę dla pliku, folderu lub projektu, ustaw jego ważność na none
w pliku konfiguracji .
[*.{cs,vb}]
dotnet_diagnostic.IDE0031.severity = none
Aby wyłączyć wszystkie reguły stylu kodu, ustaw poziom ważności kategorii Style
na none
w pliku konfiguracyjnym .
[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-Style.severity = none
Aby uzyskać więcej informacji, zobacz Jak pominąć ostrzeżenia analizy kodu.