Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일

(시리즈 글이 3개 있습니다.)
.NET Framework: 299. 해당 어셈블리가 Debug 빌드인지, Release 빌드인지 알아내는 방법
; https://www.sysnet.pe.kr/2/0/1227

.NET Framework: 315. 해당 DLL이 Managed인지 / Unmanaged인지 확인하는 방법
; https://www.sysnet.pe.kr/2/0/1279

.NET Framework: 328. 해당 DLL이 Managed인지 / Unmanaged인지 확인하는 방법 - 두 번째 이야기
; https://www.sysnet.pe.kr/2/0/1296




해당 어셈블리가 Debug 빌드인지, Release 빌드인지 알아내는 방법

국내는 어떤지 모르겠지만, 해외의 경우에는 '서비스 중인 DLL'이 Debug 빌드된 것인지, Release 빌드된 것인지를 민감하게 여기는 경우가 있는 것 같습니다. 필요 없이 성능에 손해되는 DLL로 서비스할 이유는 없으니까요.

검색을 해보면, 생각보다 쉽게 방법을 찾을 수 있습니다.

How to tell if a .NET application was compiled in DEBUG or RELEASE mode?
; http://stackoverflow.com/questions/194616/how-to-tell-if-a-net-application-was-compiled-in-debug-or-release-mode

정리해 보면, 결국 컴파일 된 DLL이 Debug인지 Release인지는 Debuggable이라는 특성에 지정된 값으로만 확인을 할 수 있습니다. 아래는 .NET Reflector로 확인해 본 것입니다.

debug_or_release_1.png

답이 모두 나왔군요. 즉, 해당 DLL을 로드한 다음 assembly 레벨에 지정된 Debuggable 특성을 살펴보면 되는 것입니다. 그런데, 어떤 값을 봐야 하는 걸까요?

일단, Visual Studio에서 Debug 모드로 빌드한 DLL은 다음와 같은 특성을 포함하고 있었습니다.

[assembly: Debuggable(DebuggableAttribute.DebuggingModes.DisableOptimizations |
                      DebuggableAttribute.DebuggingModes.EnableEditAndContinue |
                      DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints |
                      DebuggableAttribute.DebuggingModes.Default)]

반면, Release 모드로 빌드한 경우에는 결과가 다릅니다.

[assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)]

특성들을 보건데, 당연히 "DebuggableAttribute.DebuggingModes.DisableOptimizations" 옵션값이 중요합니다. 실제로, DebuggableAttribute 타입에 정의된 IsJITOptimizerDisabled 공용 속성도 다음과 같이 마이크로소프트에 의해서 코드 작성이 된 것을 볼 수 있습니다.

public bool IsJITOptimizerDisabled
{
    get
    {
        return ((this.m_debuggingModes & DebuggingModes.DisableOptimizations) != DebuggingModes.None);
    }
}

아래는, (DLL을 잠그지 않는) ReflectionOnly 버전으로 작성한 코드입니다.

static void Main(string[] args)
{
    Assembly asm = Assembly.ReflectionOnlyLoadFrom("ClassLibrary1.dll");

    foreach (var attr in asm.GetCustomAttributesData())
    {
        if (attr.Constructor.ReflectedType == typeof(DebuggableAttribute))
        {
            foreach (var arg in attr.ConstructorArguments)
            {
                if (arg.ArgumentType == typeof(System.Diagnostics.DebuggableAttribute.DebuggingModes))
                {
                    System.Diagnostics.DebuggableAttribute.DebuggingModes mode = (System.Diagnostics.DebuggableAttribute.DebuggingModes)arg.Value;

                    bool isDebug = mode.HasFlag(System.Diagnostics.DebuggableAttribute.DebuggingModes.DisableOptimizations);
                    Console.WriteLine(asm.FullName + " ==> " + isDebug);
                }
            }
        }
    }
}




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 8/12/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... 166  [167]  168  169  170  171  172  173  174  175  176  177  178  179  180  ...
NoWriterDateCnt.TitleFile(s)
910정성태8/19/201040184개발 환경 구성: 83. Hyper-V의 네트워크 유형 (1)
909정성태8/18/201035240오류 유형: 102. System.MissingMethodException
908정성태8/17/201026116개발 환경 구성: 82. Windows Virtual PC의 네트워크 유형 (3)
907정성태8/14/201023674개발 환경 구성: 81. Windows Virtual PC의 네트워크 유형 (2)
906정성태8/13/201031831개발 환경 구성: 80. Windows Virtual PC의 네트워크 유형 (1)
905정성태8/8/201035047Team Foundation Server: 39. 배치 파일로 팀 빌드 구성 [2]파일 다운로드1
904정성태8/8/201037587오류 유형: 101. SignTool Error: No certificates were found that met all the given criteria. [2]
903정성태8/6/201034509Team Foundation Server: 38. TFS 소스 코드 관리 기능 (4) - Branch
902정성태8/5/201026828Team Foundation Server: 37. TFS 2010의 소스 서버 수작업 구성
901정성태8/4/201026016Team Foundation Server: 36. TFS 소스 코드 관리 기능 (3) - Label
900정성태8/3/201028816Team Foundation Server: 35. TFS 소스 코드 관리 기능 (2) - Shelveset
899정성태8/2/201030648Team Foundation Server: 34. TFS 소스 코드 관리 기능 (1) - Changeset
898정성태7/31/201030522.NET Framework: 182. WCF의 InactivityTimeout [1]파일 다운로드1
897정성태7/26/201131657.NET Framework: 181. AssemblyVersion, AssemblyFileVersion, AssemblyInformationalVersion [4]
896정성태7/25/201038716.NET Framework: 180. C# Singleton 인스턴스 생성 [2]
895정성태7/25/201022336VS.NET IDE: 68. Visual Studio 2010 - .NET 1.1 원격 디버깅
894정성태7/25/201028313오류 유형: 100. Could not find the Database Engine startup handle. [1]
893정성태7/25/201029394오류 유형: 99. .NET 4.0 설치된 윈도우 7에서 SQL Server 2008 R2 설치 오류
892정성태7/9/201030865오류 유형: 98. 영문 윈도우에 한글 SQL Server 2008 R2 설치할 때 오류 [4]
891정성태7/8/201026961오류 유형: 97. MsiGetProductInfo failed to retrieve ProductVersion for package with Product Code = '{...}'. Error code: 1605. [2]
889정성태7/5/201028742.NET Framework: 179. Dictionary.Get(A) 대신 Dictionary.Get(A.GetHashCode())를 사용해서는 안 되는 이유 [1]
888정성태6/30/201026424오류 유형: 96. Hyper-V 연결 오류 - A connection will not be made because credentials may not be sent to the remote computer
887정성태6/23/201036376개발 환경 구성: 79. Hyper-V의 가상 머신에서 소리 재생 방법 [2]
886정성태6/23/201024256제니퍼 .NET: 14. ASMX, WCF 호출 모니터링 및 누수 확인
885정성태6/20/201026242개발 환경 구성: 78. COM+ 서버에서 COM+ 서버를 호출하는 방법
884정성태6/20/201028900제니퍼 .NET: 13. COM+ 서버 모니터링 [2]
... 166  [167]  168  169  170  171  172  173  174  175  176  177  178  179  180  ...