성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
MathJax 입력기
최근 덧글
[정성태] Detecting blocking calls using asyn...
[정성태] 아쉽게도, 커뮤니티는 아니고 개인 블로그입니다. ^^
[정성태] 질문이 잘 이해가 안 됩니다. 우선, 해당 소스코드에서 ILis...
[양승조
] var대신 dinamic으로 선언해서 해결은 했습니다. 맞는 해...
[양승조
] 또 막혔습니다. ㅠㅠ var list = props[i].Ge...
[양승조
] 아. 감사합니다. 어제는 안됐던것 같은데....정신을 차려야겠네...
[정성태] "props[i].GetValue(props[i])" 코드에서 ...
[정성태] 저렇게 조각 코드 말고, 실제로 재현이 되는 예제 프로젝트를 압...
[정성태] Modules 창(Ctrl+Shift+U)을 띄워서, 해당 Op...
[정성태] 만드실 수 있습니다. 단지, Unity 엔진 내의 스크립트와 W...
글쓰기
제목
이름
암호
전자우편
HTML
홈페이지
유형
제니퍼 .NET
닷넷
COM 개체 관련
스크립트
VC++
VS.NET IDE
Windows
Team Foundation Server
디버깅 기술
오류 유형
개발 환경 구성
웹
기타
Linux
Java
DDK
Math
Phone
Graphics
사물인터넷
부모글 보이기/감추기
내용
<div style='display: inline'> <h1 style='font-family: Malgun Gothic, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>소스 코드가 없는 닷넷 어셈블리를 디버깅할 때 지역 변숫값을 확인하는 방법</h1> <p> 예전에 다음과 같은 글을 소개해 드렸는데요.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > .NET Reflector를 이용한 "소스 코드가 없는" 어셈블리 디버깅 ; <a target='tab' href='http://www.sysnet.pe.kr/2/0/1201'>http://www.sysnet.pe.kr/2/0/1201</a> </pre> <br /> 이 방법을 이용해 디버깅을 하다 보면, 지역 변수의 값이 디버그 Watch 창에 안 보이는 경우가 있습니다.<br /> <br /> <img alt='suppress_jit_opt_1.png' src='/SysWebRes/bbs/suppress_jit_opt_1.png' /><br /> <br /> <div style='BACKGROUND-COLOR: #ccffcc; padding: 10px 10px 5px 10px; MARGIN: 0px 10px 10px 10px; FONT-FAMILY: Malgun Gothic, Consolas, Verdana; COLOR: #005555'> Cannot obtain value of the local variable or argument because it is not available at this instruction pointer, possibly because it has been optimized away.<br /> </div><br /> <br /> 이를 완화시키기 위해 COMPLUS_ZapDisable 옵션을 소개해 드린 적이 있는데요.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > COMPLUS_ZapDisable - JIT 최적화 코드 생성 제어 ; <a target='tab' href='http://www.sysnet.pe.kr/2/0/646'>http://www.sysnet.pe.kr/2/0/646</a> .NET JIT 최적화 코드 생성 제어 ; <a target='tab' href='https://www.sysnet.pe.kr/2/0/656'>https://www.sysnet.pe.kr/2/0/656</a> </pre> <br /> 그런데... 이상하군요. 이 방법이 Visual Studio 2015에서 동작하질 않습니다. "SET COMPLUS_ZapDisable=1"을 설정해도 여전히 닷넷 어셈블리 DLL들이 "Optimized" 상태로 올라옵니다.<br /> <br /> 검색해 보니, 다음의 글이 나옵니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; background-color: #fbedbb; overflow: auto; font-family: Consolas, Verdana;' > Cannot obtain value of local or argument as it is not available at this instruction pointer, possibly because it has been optimized away ; <a target='tab' href='http://stackoverflow.com/questions/8311303/cannot-obtain-value-of-local-or-argument-as-it-is-not-available-at-this-instruct'>http://stackoverflow.com/questions/8311303/cannot-obtain-value-of-local-or-argument-as-it-is-not-available-at-this-instruct</a> </pre> <br /> 즉, "Debug" / "Options" 메뉴에서 "Debugging" / "General" 범주의 "Suppress JIT optimization on module load (Managed only)" 옵션을 켜준다는 것인데요. (한글 메뉴: "모듈 로드 시 JIT 최적화 기능 사용 중지(관리 전용)")<br /> <br /> <img onclick='toggle_img(this)' class='imgView' alt='suppress_jit_opt_2.png' src='/SysWebRes/bbs/suppress_jit_opt_2.png' /><br /> <br /> 재미있는 것은 그래도 일부 로컬 변수의 값들은 여전히 "Cannot obtain value of the local variable or argument because it is not available at this instruction pointer, possibly because it has been optimized away." 상태로 출력됩니다.<br /> <br /> 하지만, 2가지 옵션을 모두 적용(COMPLUS_ZapDisable, Suppress JIT optimization...)하는 경우에는 다음과 같이 모든 로컬 변수들의 값이 잘 나왔고, mscorlib.dll도 "Optimized == No" 상태로 로드가 되었습니다.<br /> <br /> <img alt='suppress_jit_opt_3.png' src='/SysWebRes/bbs/suppress_jit_opt_3.png' /><br /> <br /> <hr style='width: 50%' /><br /> <br /> 참고로, 이런 식의 디버깅 환경에서 작업할 때는 프로젝트의 "Enable the Visual Studio hosting process" 옵션을 끄는 것이 좋습니다. 이 옵션으로 인해 "Suppress JIT optimization..." 설정이 곧바로 반영되지 않는 등의 부작용이 있습니다.<br /> </p><br /> <br /><hr /><span style='color: Maroon'>[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
7012
(왼쪽의 숫자를 입력해야 합니다.)