CA1510: Använd ArgumentNullException throw helper
Property | Värde |
---|---|
Regel-ID | CA1510 |
Title | Använda ArgumentNullException throw helper |
Kategori | Underhåll |
Korrigeringen är icke-bakåtkompatibel | Icke-breaking |
Aktiverad som standard i .NET 9 | Som förslag |
Orsak
Koden kontrollerar om ett argument är null
och sedan villkorligt genererar en ArgumentNullException.
Regelbeskrivning
Argumentkontroller har en betydande inverkan på kodstorleken och dominerar ofta koden för små funktioner och egenskapsuppsättningar. Dessa kontroller förhindrar inlining och orsakar betydande förorening av instruktionscache. Throw-helper-metoder som ArgumentNullException.ThrowIfNull är enklare och effektivare än if
block som konstruerar en ny undantagsinstans.
Exempel
Följande kodfragment visar ett brott mot CA1510:
void M(string arg)
{
if (arg is null)
throw new ArgumentNullException(nameof(arg));
}
Följande kodfragment visar korrigeringen:
void M(string arg)
{
ArgumentNullException.ThrowIfNull(arg);
}
Så här åtgärdar du överträdelser
Ersätt blocket if
som utlöser undantaget med ett anrop till ArgumentNullException.ThrowIfNull. I Visual Studio kan du också använda glödlampans meny för att korrigera koden automatiskt.
När du ska ignorera varningar
Det är säkert att förhindra en överträdelse av den här regeln om du inte bryr dig om kodens underhållbarhet. Det är också bra att förhindra överträdelser som identifieras som falska positiva identifieringar.
Ignorera en varning
Om du bara vill förhindra en enda överträdelse lägger du till förprocessordirektiv i källfilen för att inaktivera och aktiverar sedan regeln igen.
#pragma warning disable CA1510
// The code that's violating the rule is on this line.
#pragma warning restore CA1510
Om du vill inaktivera regeln för en fil, mapp eller ett projekt anger du dess allvarlighetsgrad till none
i konfigurationsfilen.
[*.{cs,vb}]
dotnet_diagnostic.CA1510.severity = none
Mer information finns i Så här utelämnar du kodanalysvarningar.