Microsoft MVP성태의 닷넷 이야기
디버깅 기술: 219. WinDbg - 명령어 내에서 환경 변수 사용법 [링크 복사], [링크+제목 복사],
조회: 4337
글쓴 사람
정성태 (seongtaejeong at gmail.com)
홈페이지
첨부 파일
 

(시리즈 글이 2개 있습니다.)
디버깅 기술: 216. WinDbg - 2가지 유형의 식 평가 방법(MASM, C++)
; https://www.sysnet.pe.kr/2/0/13860

디버깅 기술: 219. WinDbg - 명령어 내에서 환경 변수 사용법
; https://www.sysnet.pe.kr/2/0/13910




WinDbg - 명령어 내에서 환경 변수 사용법

아쉽게도 WinDbg의 표현식에서 환경 변수를 사용할 수는 없습니다.

그래서, .load와 같은 명령어를 사용할 때 (윈도우 명령행처럼) 환경 변수를 이용하면 오류가 발생합니다.

0:00> .load "%USERPROFILE%\\.dotnet\\sos\\sos.dll"
The call to LoadLibrary(%USERPROFILE%\.dotnet\sos\sos.dll) failed, Win32 error 0n2
    "The system cannot find the file specified."
...[생략]...

위의 결과에도 나오지만, "%USERPROFILE%"을 환경 변수로 인식하는 것이 아니라 경로명 자체로 인식하기 때문입니다.

대신, 우회하는 방법이 하나 있긴 한데요, "as" 명령어를 이용해,

as, aS (Set Alias)
; https://learn.microsoft.com/en-us/windows-hardware/drivers/debuggercmds/as--as--set-alias-

이렇게 WinDbg 변수로 정의할 수 있습니다.

// https://community.osr.com/t/how-to-nest-if-token/39299/5

0:014> as /e MyEnvVar USERPROFILE

그럼, 다음과 같이 각종 WinDbg 명령에서 사용할 수 있습니다.

0:014> .echo ${MyEnvVar}
C:\Users\testusr

0:014> .load ${MyEnvVar}\.dotnet\sos\sos.dll

0:014> .chain
Extension DLL search Path:
    ...[생략]...
Extension DLL chain:
    C:\Users\testusr\.dotnet\sos\sos.dll: image 9,0,12,7501 @Commit: a651406e39038aef1dbc7c8097b52953284dba27, API 2.0.0, built Sat Jan 25 17:30:17 2025
        [path: C:\Users\testusr\.dotnet\sos\sos.dll]
    kdexts: image 10.0.27793.1000, API 1.0.0, 
    ...[생략]...




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







[최초 등록일: ]
[최종 수정일: 4/8/2025]

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

비밀번호

댓글 작성자
 




... 196  [197]  198  199  200  201 
NoWriterDateCnt.TitleFile(s)
107정성태3/1/200522255COM 개체 관련: 15. COM: Control 유형인 경우, IObjectWithSite 를 구현해도 SetSite/GetSite 가 호출이 안됨
106정성태2/28/200521768COM 개체 관련: 14. 탐색기 "처럼" 파일 열기
105정성태2/28/200520604.NET Framework: 26. VS.NET 2005 : 설치 프로젝트 - .NET Framework 설치 강제화
139정성태11/14/200518952    답변글 .NET Framework: 26.1. ^^ 역시, 배려가 되어 있네요. 제가 못 찾은 것이었습니다.
104정성태2/27/200521686VS.NET IDE: 23. MSI 설치 중에 GetLocalTime / GetSystemTime API 사용
132정성태3/30/200521206    답변글 VS.NET IDE: 23.1. [추가]: MSI 설치 동작 원리
102정성태2/16/200524229.NET Framework: 25. Verify that you are a member of the 'Debugger Users' group on the server. [2]
101정성태2/15/200522135.NET Framework: 24. WMI Win32_NTLogEvent 관리 이벤트를 Windows 2000 에서는 "Access Denied" 가 발생하는 문제파일 다운로드1
100정성태2/15/200528357VS.NET IDE: 22. 방화벽 환경에서의 WMI 연결을 위한 포트 설정 [2]
99정성태2/15/200526410COM 개체 관련: 13. 비동기 Drag & Drop 구현 : IAsyncOperation
103정성태2/23/200522345    답변글 COM 개체 관련: 13.1. [관련 자료] 그외 Drag & Drop 링크파일 다운로드1
97정성태2/14/200525105VS.NET IDE: 21. 설치된 Platform SDK 버전확인 방법
96정성태2/14/200527034기타: 9. http://www.google.com/webhp?complete=1&hl=en 검색에 관해서.
95정성태2/14/200536634VS.NET IDE: 20. Win32 특권 정리 [1]
94정성태1/29/200527668VC++: 13. VS.NET 2005 VC++ 컴파일러 에러 : cannot instantiate abstract class
93정성태1/29/200523407VS.NET IDE: 19. 혹시 VS.NET 2005 Beta2(2004/12 CTP Team System 버전)이 다운이 자주 되나요? [2]
92정성태1/29/200521943.NET Framework: 23. Unmanaged 환경에서 Managed DLL에 정의된 메서드 호출 시 오류 확인하는 방법
91정성태11/14/200522598VC++: 12. VS.NET 2005 VC++ Debug: Expression: ( (state != ST_INVALID ) )
90정성태1/27/200523765.NET Framework: 22. Debug: The underlying connection was closed: Unable to connect to the remote server.
89정성태1/26/200528176VC++: 11. Delay Loaded DLL
87정성태1/23/200521816VS.NET IDE: 18. VS.NET 2005 Beta 1 - VC++ 프로젝트에서 Connection Point 구현시 버그
88정성태1/23/200521211    답변글 VS.NET IDE: 18.1. VS.NET 2003 : VC++ 프로젝트에서 Connection Point 추가시에도 버그
86정성태1/23/200527275.NET Framework: 21. Code Snippet - Enum과 관련된 다양한 형변환 [1]
85정성태1/23/200525535스크립트: 4. Windows 2003에서 BHO(Browser Helper Objects) 동작 안하는 현상 [1]
83정성태1/18/200530932.NET Framework: 20. System.AccessViolationException 예외가 발생한 한 예.
82정성태1/3/200524264VS.NET IDE: 17. Windows 운영 - 특정 사용자 또는 그룹에 대해서 파일 공유 접근 금지
... 196  [197]  198  199  200  201