다음을 통해 공유


불필요한 제거(IDE0079)

재산
규칙 ID IDE0079
타이틀 불필요한 표시 안 함 제거
범주 CodeQuality
하위 범주 불필요한 코드 규칙(비표시 기본 설정)
적용 가능한 언어 C# 및 Visual Basic
옵션 dotnet_remove_unnecessary_suppression_exclusions

개요

이 규칙은 소스에서 불필요한 pragmaSuppressMessageAttribute 특성 표시 안 함 플래그를 지정합니다.

소스 억제는 소스 코드의 다른 부분이 아닌 특정 위치에서 컴파일러 및 분석기 규칙 위반을 표시하지 않습니다. 일반적으로 가양성 또는 수정하지 않으려는 덜 중요한 위반을 표시하지 않는 데 사용합니다. 그러나 억제는 종종 부실해집니다. 이 문제는 가양성 방지를 위해 규칙이 수정되었거나 코드를 리팩터링하여 제거를 중복 렌더링하는 경우에 발생할 수 있습니다. 이 규칙은 제거할 수 있는 중복 제거를 식별하는 데 도움이 됩니다.

메모

빌드코드 스타일 규칙을 사용하도록 설정할 있더라도 이 규칙은 사용하도록 설정되지 않습니다. 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

자세한 내용은 코드 분석 경고표시하지 않는 방법을 참조하세요.

참고 항목