共用方式為


CA1871:請勿將可空結構體傳遞至 'ArgumentNullException.ThrowIfNull'

財產 價值
規則標識碼 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

如需詳細資訊,請參閱 如何在隱藏程式代碼分析警告。