删除不必要的抑制(IDE0079)

财产 价值
规则 ID IDE0079
游戏 删除不必要的抑制
类别 CodeQuality
子类别 不必要的代码规则(抑制首选项)
适用的语言 C# 和 Visual Basic
选项 dotnet_remove_unnecessary_suppression_exclusions

概述

此规则标记源中不必要的杂注 杂注SuppressMessageAttribute 属性抑制。

源抑制可禁止特定位置的编译器和分析器规则冲突,但不会在源代码的其他部分显示。 通常使用它们来禁止误报或不太重要的违规行为,而你不打算修复这些违规行为。 但是,抑制往往变得过时。 如果已修复规则以防止误报,或者重构代码,并且这样做,呈现抑制冗余,则可能会发生这种情况。 此规则有助于识别可以删除的冗余抑制。

注意

即使 在生成上启用代码样式规则,也不会启用此规则。 它仅在 Visual Studio 编辑器中浮出水面。

using System.Diagnostics.CodeAnalysis;

class C1
{
    // Necessary pragma suppression
#pragma warning disable IDE0051 // IDE0051: Remove unused member
    private int UnusedMethod() => 0;
#pragma warning restore IDE0051

    // IDE0079: Unnecessary pragma suppression
#pragma warning disable IDE0051 // IDE0051: Remove unused member
    private int UsedMethod() => 0;
#pragma warning restore IDE0051

    public int PublicMethod() => UsedMethod();
}

class C2
{
    // Necessary SuppressMessage attribute suppression
    [SuppressMessage("CodeQuality", "IDE0051:Remove unused private members", Justification = "<Pending>")]
    private int _unusedField;

    // IDE0079: Unnecessary SuppressMessage attribute suppression
    [SuppressMessage("CodeQuality", "IDE0051:Remove unused private members", Justification = "<Pending>")]
    private int _usedField;

    public int PublicMethod2() => _usedField;
}

选项

选项指定希望规则强制实施的行为。 有关配置选项的信息,请参阅 选项格式

注意

设置格式 option_name = value:severity 的严重性不适用于 dotnet_remove_unnecessary_suppression_exclusions 选项,应避免。 而是使用单独的条目指定严重性,例如:

dotnet_remove_unnecessary_suppression_exclusions = none
dotnet_diagnostic.IDE0079.severity = warning

dotnet_remove_unnecessary_suppression_exclusions

财产 价值 描述
选项名称 dotnet_remove_unnecessary_suppression_exclusions
选项值 以逗号分隔的规则 ID 或类别列表(以 category:为前缀) 排除列出的规则或类别的抑制
all 禁用规则(排除的所有规则 ID)
none 为所有规则启用规则(无排除项)
默认选项值 none
using System.Diagnostics.CodeAnalysis;

class C1
{
    // 'dotnet_remove_unnecessary_suppression_exclusions = IDE0051'

    // Unnecessary pragma suppression, but not flagged by IDE0079
#pragma warning disable IDE0051 // IDE0051: Remove unused member
    private int UsedMethod() => 0;
#pragma warning restore IDE0051

    public int PublicMethod() => UsedMethod();
}

禁止显示警告

如果只想取消单个冲突,请将预处理器指令添加到源文件以禁用,然后重新启用规则。

#pragma warning disable IDE0079
// The code that's violating the rule is on this line.
#pragma warning restore IDE0079

若要禁用文件、文件夹或项目的规则,请将其严重性设置为 配置文件中的 none

[*.{cs,vb}]
dotnet_diagnostic.IDE0079.severity = none

若要禁用此整个规则类别,请将类别的严重性设置为 配置文件中的 none

[*.{cs,vb}]
dotnet_analyzer_diagnostic.category-CodeQuality.severity = none

有关详细信息,请参阅 如何取消代码分析警告

另请参阅