다음을 통해 공유


CA1837: Process.GetCurrentProcess() 대신 Environment.ProcessId를 사용합니다.

속성
규칙 ID CA1837
제목 ‘Process.GetCurrentProcess().Id’ 대신 ‘Environment.ProcessId’ 사용
범주 성능
수정 사항이 호환성을 깨뜨리는지 여부 또는 무중단인지 여부 주요 변경 아님
.NET 10에서 기본적으로 사용하도록 설정 제안 사항
적용 가능한 언어 C# 및 Visual Basic

원인

이 규칙은 System.Diagnostics.Process.GetCurrentProcess().Id에 대한 호출을 찾고 보다 효율적인 System.Environment.ProcessId를 대신 사용하도록 제안합니다.

규칙 설명

System.Diagnostics.Process.GetCurrentProcess().Id는 비용이 많이 듭니다.

  • 일반적으로 Process를 가져오기 위해서만 Id 인스턴스를 할당합니다.
  • 성능에 영향을 주는 Process 인스턴스를 삭제해야 합니다.
  • Dispose() 인스턴스에서 Process를 호출하는 것을 잊어버리기 쉽습니다.
  • Id 이외의 다른 항목에서 Process 인스턴스를 사용하지 않으면 참조된 형식의 그래프가 증가하여 연결된 크기가 불필요하게 증가합니다.
  • 이 API를 검색하거나 찾기가 약간 어렵습니다.

System.Environment.ProcessId는 위의 항목을 모두 방지합니다.

주의

규칙 CA1837은 .NET 5.0부터 사용할 수 있습니다.

위반 문제를 해결하는 방법

위반은 수동으로 해결하거나, 경우에 따라 바로 가기를 사용하여 Visual Studio에서 코드를 수정할 수 있습니다.

다음 두 코드 조각은 규칙의 위반과 위반을 해결하는 방법을 보여 줍니다.

using System.Diagnostics;

class MyClass
{
    void MyMethod()
    {
        int pid = Process.GetCurrentProcess().Id;
    }
}
Imports System.Diagnostics

Class MyClass
    Private Sub MyMethod()
        Dim pid As Integer = Process.GetCurrentProcess().Id
    End Function
End Class
using System.Diagnostics;

class MyClass
{
    void MyMethod()
    {
        int pid = System.Environment.ProcessId;
    }
}
Imports System.Diagnostics

Class MyClass
    Private Sub MyMethod()
        Dim pid As Integer = System.Environment.ProcessId
    End Function
End Class

Visual Studio에서는 이 규칙에 대한 코드 수정 사항을 사용할 수 있습니다. 이를 사용하려면 위반에 커서를 놓고 Ctrl+. (마침표) 키를 누르세요. 옵션 목록이 표시되면 ‘Process.GetCurrentProcess().Id’ 대신 ‘Environment.ProcessId’를 사용하세요를 선택합니다.

CA1837에 대한 코드 수정 사항 - ‘Process.GetCurrentProcess().Id’ 대신 ‘Environment.ProcessId’ 사용

경고를 표시하지 않는 경우

Process 인스턴스의 불필요한 할당 및 삭제가 성능에 미치는 영향이 중요하지 않은 경우 이 규칙의 위반을 표시하지 않아도 됩니다.

경고 표시 안 함

단일 위반을 억제하려면 원본 파일에 전처리기 지시문을 추가하여 규칙을 비활성화한 후 다시 활성화하십시오.

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

파일, 폴더 또는 프로젝트에 대한 규칙을 사용하지 않으려면 구성 파일에서 none의 심각도를 설정합니다.

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

자세한 내용은 방법: 코드 분석 경고 표시 안 함을 참조하세요.

참고하기