CA1507: Verwenden von nameof
anstelle der Zeichenfolge
Eigenschaft | Wert |
---|---|
Regel-ID | CA1507 |
Titel | Verwenden von nameof anstelle der Zeichenfolge |
Kategorie | Wartbarkeit |
Fix führt oder führt nicht zur Unterbrechung | Nicht unterbrechend |
Standardmäßig in .NET 9 aktiviert | Als Vorschlag |
Ursache
Ein string
-Literal oder eine -Konstante, die mit dem Namen eines Parameters der enthaltenden Methode oder dem Namen einer Eigenschaft des enthaltenden Typs übereinstimmt, wird als Argument für eine Methode verwendet.
Regelbeschreibung
Rule CA1507 kennzeichnet die Verwendung eines string
Literals als Argument für eine Methode oder einen Konstruktor an, bei der ein nameof (NameOf
in Visual Basic) Ausdruck die Wartbarkeit erhöhen würde. Die Regel wird ausgelöst, wenn alle der folgenden Bedingungen erfüllt sind:
Das Argument ist
string
-Literal oder eine -Konstante.Das-Argument entspricht einem
string
-typisierten Parameter der Methode oder dem Konstruktor, der aufgerufen wird (d. h., es ist keine Konvertierung an der Aufruf-Site beteiligt).Entweder:
Der deklarierte Name des Parameters ist
paramName
und der konstante Wert desstring
-Literals entspricht dem Namen eines Parameters der Methode, der Lambda-Funktion oder der lokalen Funktion, in der die Methode oder der Konstruktor aufgerufen wird.Der deklarierte Name des Parameters ist
propertyName
und der konstante Wert desstring
-Literals entspricht dem Namen eines Parameters der Methode, der Lambda-Funktion oder der lokalen Funktion, in der die Methode oder der Konstruktor aufgerufen wird.
Rule CA1507 verbessert die Code-Wartbarkeit in Fällen, in denen der Parameter in Zukunft umbenannt werden kann, das string
-Literal aber versehentlich nicht umbenannt wird. Mithilfe von nameof
wird das Symbol umbenannt, wenn der Parameter durch einen Umgestaltungsvorgang umbenannt wird. Außerdem werden alle Rechtschreibfehler im Namen des Parameters vom Compiler abgefangen.
Behandeln von Verstößen
Um einen Verstoß zu beheben, ersetzen Sie das string
-Literal durch einen nameof (NameOf
in Visual Basic) Ausdruck. Die folgenden beiden Codeausschnitte zeigen z. B. einen Verstoß gegen die Regel und wie dieser korrigiert werden kann:
public Book(string title)
{
// Violates rule CA1507
Title = title ?? throw new ArgumentNullException("title", "All books must have a title.");
}
public Book(string title)
{
// Resolves rule CA1507 violation
Title = title ?? throw new ArgumentNullException(nameof(title), "All books must have a title.");
}
Tipp
Für diese Regel ist ein Codefix in Visual Studio verfügbar. Um sie zu verwenden, muss der Cursor auf dem string
-Literal platziert und Ctrl+. (Punkt) gedrückt werden. Wählen Sie Verwenden von nameof zum Ausdrücken von Symbolnamen aus der Liste der angezeigten Optionen aus.
Wann sollten Warnungen unterdrückt werden?
Es ist sicher, einen Verstoß gegen diese Regel zu unterdrücken, wenn Sie sich keine Gedanken über die Wartbarkeit Ihres Codes machen.
Unterdrücken einer Warnung
Um nur eine einzelne Verletzung zu unterdrücken, fügen Sie der Quelldatei Präprozessoranweisungen hinzu, um die Regel zu deaktivieren und dann wieder zu aktivieren.
#pragma warning disable CA1507
// The code that's violating the rule is on this line.
#pragma warning restore CA1507
Um die Regel für eine Datei, einen Ordner oder ein Projekt zu deaktivieren, legen Sie den Schweregrad in der Konfigurationsdatei auf none
fest.
[*.{cs,vb}]
dotnet_diagnostic.CA1507.severity = none
Weitere Informationen finden Sie unter Vorgehensweise: Unterdrücken von Codeanalyse-Warnungen.