Share via


CA1839: Process.GetCurrentProcess().MainModule.FileName 대신 Environment.ProcessPath 사용

속성
규칙 ID CA1839
타이틀 Process.GetCurrentProcess() 대신 Environment.ProcessPath를 사용합니다. MainModule.FileName
범주 성능
수정 사항이 주요 변경인지 여부 주요 변경 아님
.NET 8에서 기본적으로 사용 제안 사항

원인

프로세스를 시작한 파일의 경로를 가져오는 데 Environment.ProcessPath 대신 Process.GetCurrentProcess().MainModule.FileName을 사용합니다.

규칙 설명

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

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

System.Environment.ProcessPath는 이러한 단점을 모두 방지하면서 동일한 정보를 생성합니다.

참고 항목

System.Environment.ProcessPath는 .NET 6부터 사용할 수 있습니다.

위반 문제를 해결하는 방법

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

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

using System.Diagnostics;

class MyClass
{
    void MyMethod()
    {
        string path = Process.GetCurrentProcess().MainModule.FileName; // Violation occurs
    }
}
Imports System.Diagnostics

Class MyClass
    Private Sub MyMethod()
        Dim path As String = Process.GetCurrentProcess().MainModule.FileName ' Violation occurs.
    End Function
End Class
using System.Diagnostics;

class MyClass
{
    void MyMethod()
    {
        string path = System.Environment.ProcessPath; // Violation fixed
    }
}
Imports System.Diagnostics

Class MyClass
    Private Sub MyMethod()
        Dim path As String = System.Environment.ProcessPath ' Violation fixed.
    End Function
End Class

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

Code fix for CA1839 - Use 'Environment.ProcessPath'

경고를 표시하지 않는 경우

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

경고 표시 안 함

단일 위반만 표시하지 않으려면 원본 파일에 전처리기 지시문을 추가하여 규칙을 사용하지 않도록 설정한 후 다시 사용하도록 설정합니다.

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

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

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

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

참고 항목