| 財產 | 價值 |
|---|---|
| 規則標識碼 | CA1871 |
| 標題 | 請勿將可為 Null 的結構體傳遞至 'ArgumentNullException.ThrowIfNull' |
| 類別 | 效能 |
| 修正可能造成系統中斷或維持正常運作 | 非中斷 |
| 在 .NET 10 中預設啟用 | 作為資訊 |
原因
當可為 Null 的結構,例如 int? 或 Guid?,傳遞至 ArgumentNullException.ThrowIfNull時,它會被封裝為物件,因而造成效能損失。
規則描述
為了提升效能,最好檢查 HasValue 屬性,並手動拋出例外,而不是將可為 Null 的結構傳遞到 ArgumentNullException.ThrowIfNull。
如何修正違規
檢查 null 並手動拋出 ArgumentNullException。
例
下列代碼段顯示 CA1871 的違規:
static void Print(int? value)
{
ArgumentNullException.ThrowIfNull(value);
Console.WriteLine(value.Value);
}
下列代碼段會修正違規:
static void Print(int? value)
{
if (!value.HasValue)
{
throw new ArgumentNullException(nameof(value));
}
Console.WriteLine(value.Value);
}
隱藏警告的時機
如果不考慮性能問題,忽略此警告是安全的。
隱藏警告
如果您只想要隱藏單一違規,請將預處理器指示詞新增至原始程式檔以停用,然後重新啟用規則。
#pragma warning disable CA1871
// The code that's violating the rule is on this line.
#pragma warning restore CA1871
若要停用檔案、資料夾或項目的規則,請將其嚴重性設定為 組態檔中的 none。
[*.{cs,vb}]
dotnet_diagnostic.CA1871.severity = none
如需詳細資訊,請參閱 如何在隱藏程式代碼分析警告。