성태의 닷넷 이야기
홈 주인
모아 놓은 자료
프로그래밍
질문/답변
사용자 관리
사용자
메뉴
아티클
외부 아티클
유용한 코드
온라인 기능
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'> <div style='font-family: 맑은 고딕, Consolas; font-size: 20pt; color: #006699; text-align: center; font-weight: bold'>.NET 4.0 응용 프로그램의 Main 함수에 BreakPoint 걸기</div> <br /> 예전에 CLR 2.0 응용 프로그램의 Main 함수에 중지점(BreakPoint)를 거는 방법을 설명했었지요.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; width: 800px; background-color: #fbedbb; overflow-x: scroll; font-family: Consolas, Verdana;' > (Managed) Main Method에 Break Point 걸기 ; <a target='_tab' href='http://www.sysnet.pe.kr/2/0/469'>http://www.sysnet.pe.kr/2/0/469</a> </pre> <br /> .NET 4.0을 대상으로 한다면 위의 설명에서 다소 맞지 않는 부분이 있어서 '개정판' 차원에서 ^^ 언급해 보겠습니다.<br /> <br /> 우선, mscorwks.dll 로딩 시에 BP를 걸었던 것을 clr.dll로 바꿔주는 것으로 시작합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; width: 800px; background-color: #fbedbb; overflow-x: scroll; font-family: Consolas, Verdana;' > 01: 0:000> <b style='COLOR: blue'>sxe ld clr</b> </pre> <br /> 'g' 명령어로 이제 clr.dll이 로드될 때까지 진행합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; width: 800px; background-color: #fbedbb; overflow-x: scroll; font-family: Consolas, Verdana;' > 0:000> <b style='COLOR: blue'>g</b> ModLoad: 70070000 706e0000 <b style='COLOR: blue'>C:\Windows\Microsoft.NET\Framework\v4.0.30319\clr.dll</b> eax=00000000 ebx=00000000 ecx=00000000 edx=00000000 esi=7efdd000 edi=001ef400 eip=7778fc52 esp=001ef2d4 ebp=001ef328 iopl=0 nv up ei pl zr na pe nc cs=0023 ss=002b ds=002b es=002b fs=0053 gs=002b efl=00000246 ntdll!ZwMapViewOfSection+0x12: 7778fc52 83c404 add esp,4 </pre> <br /> <a target='_tab' href='http://www.sysnet.pe.kr/2/0/943'>clr이 로드되었으니, 안전하게 sos.dll을 로드</a>해 주고,<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; width: 800px; background-color: #fbedbb; overflow-x: scroll; font-family: Consolas, Verdana;' > 0:000> <b style='COLOR: blue'>.loadby sos clr</b> 0:000> .chain Extension DLL search Path: C:\Program Files (x86)\...[생략]...\COMMON Extension DLL chain: C:\Windows\Microsoft.NET\Framework\v4.0.30319\sos: image 4.0.30319.225, API 1.0.0, built Thu Feb 10 13:49:57 2011 <b style='COLOR: blue'>[path: C:\Windows\Microsoft.NET\Framework\v4.0.30319\sos.dll]</b> dbghelp: image 6.12.0002.633, API 6.1.6, built Tue Feb 02 05:08:26 2010 [path: C:\...[생략]...\dbghelp.dll] ext: image 6.12.0002.633, API 1.0.0, built Tue Feb 02 05:08:31 2010 [path: C:\...[생략]...\ext.dll] wow64exts: image 6.1.7650.0, API 1.0.0, built Tue Feb 02 05:08:04 2010 [path: C:\...[생략]...\wow64exts.dll] exts: image 6.12.0002.633, API 1.0.0, built Tue Feb 02 05:08:24 2010 [path: C:\...[생략]...\exts.dll] uext: image 6.12.0002.633, API 1.0.0, built Tue Feb 02 05:08:23 2010 [path: C:\...[생략]...\uext.dll] ntsdexts: image 6.1.7650.0, API 1.0.0, built Tue Feb 02 05:08:08 2010 [path: C:\...[생략]...\ntsdexts.dll] </pre> <br /> RunMain 함수에 BP를 걸어주고, 해당 함수에서 멈출 때까지 'g' 키를 눌러 진행합니다.<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; width: 800px; background-color: #fbedbb; overflow-x: scroll; font-family: Consolas, Verdana;' > 0:000> <b style='COLOR: blue'>bp clr!ClassLoader::RunMain</b> 0:000> <b style='COLOR: blue'>g</b> (10e0.1074): Unknown exception - code 04242420 (first chance) ModLoad: 73750000 737b0000 C:\Windows\Microsoft.NET\Framework\v4.0.30319\clrjit.dll eax=00000000 ebx=00000000 ecx=00000002 edx=00000000 esi=7efdd000 edi=001ee164 eip=7778fc52 esp=001ee038 ebp=001ee08c iopl=0 nv up ei pl zr na pe nc cs=0023 ss=002b ds=002b es=002b fs=0053 gs=002b efl=00000246 ntdll!ZwMapViewOfSection+0x12: 7778fc52 83c404 add esp,4 0:000> <b style='COLOR: blue'>g</b> Breakpoint 0 hit eax=001ef104 ebx=00000000 ecx=700f5b79 edx=80000001 esi=002a33f0 edi=00000000 eip=7012212f esp=001ef0cc ebp=001ef330 iopl=0 nv up ei pl nz na pe nc cs=0023 ss=002b ds=002b es=002b fs=0053 gs=002b efl=00000206 <b style='COLOR: blue'>clr!ClassLoader::RunMain:</b> 7012212f 6838010000 push 138h </pre> <br /> 마지막으로 예와 다름없이 Main 메서드에 bp를 걸어주면 끝!<br /> <br /> <pre style='margin: 10px 0px 10px 10px; padding: 10px 0px 10px 10px; width: 800px; background-color: #fbedbb; overflow-x: scroll; font-family: Consolas, Verdana;' > !bpmd ConsoleApplication1 ConsoleApplication1.Program.Main </pre> <br /> <br /><br /><hr /><span style='color: Maroon'>[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]</span> </div>
첨부파일
스팸 방지용 인증 번호
3415
(왼쪽의 숫자를 입력해야 합니다.)