CA1839: Process.GetCurrentProcess().MainModule.FileName 대신 Environment.ProcessPath 사용
속성 | 값 |
---|---|
규칙 ID | CA1839 |
제목 | Process.GetCurrentProcess() 대신 Environment.ProcessPath를 사용합니다. MainModule.FileName |
범주 | 성능 |
수정 사항이 주요 변경인지 여부 | 주요 변경 아님 |
.NET 9에서 기본적으로 사용 | 제안 사항 |
원인
프로세스를 시작한 파일의 경로를 가져오는 데 Environment.ProcessPath 대신 Process.GetCurrentProcess().MainModule.FileName
을 사용합니다.
규칙 설명
System.Diagnostics.Process.GetCurrentProcess().MainModule.FileName
는 비용이 많이 듭니다.
- 일반적으로 Process 및 ProcessModule 인스턴스는
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' 사용을 선택합니다.
경고를 표시하지 않는 경우
Process 및 ProcessModule 인스턴스의 불필요한 할당 및 삭제가 성능에 미치는 영향이 중요하지 않은 경우 이 규칙의 위반을 표시하지 않아도 됩니다.
경고 표시 안 함
단일 위반만 표시하지 않으려면 원본 파일에 전처리기 지시문을 추가하여 규칙을 사용하지 않도록 설정한 후 다시 사용하도록 설정합니다.
#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
자세한 내용은 방법: 코드 분석 경고 표시 안 함을 참조하세요.
참고 항목
.NET