Microsoft MVP성태의 닷넷 이야기
디버깅 중 이해할 수 없는 상황이 [링크 복사], [링크+제목 복사],
조회: 12491
글쓴 사람
임동찬 (dngchn.im at samsung.com)
홈페이지
첨부 파일
 

요즘 제가 게시판을 도배하는 듯 해서 자제하려고 하는데도 자꾸만 정책임님 생각이 나네요.. ^^
...
요즘 작업하는 프로젝트를 디버깅하다보면요.
예를 들어
void sampleMethod()
{
...
string tmpString = GetStringFromXXX();
// position A
string tmpString2 = tmpString; // dummy code
// position B
...
}

위와 같은식의 메서드 실행 중
A 위치에서 tmpString에 대해 watch창에서나 커서를 올려두고 값을 확인하고자 하는데 안됩니다.
watch창에서는 The name 'tmpString' does not exist in the current context.가 나오네요.
그래서 dummy code를 실행한 이후의 B위치에서나 비로소 그 값이 확인 됩니다.

이럴 수도 있는지요?

 








[최초 등록일: ]
[최종 수정일: 8/19/2010]


비밀번호

댓글 작성자
 



2010-08-20 12시22분
음... 재현할 수 있는 환경이 앞에 있어야 할 것 같은데요. ^^

혹시 Release 로 컴파일 된 어셈블리를 디버깅하시는 건가요? 릴리즈 모드로 빌드된 경우 최적화가 이뤄지기 때문에 메서드가 inline 화 되는 등... 의 생략으로 인해 그런 현상이 발생할 수 있습니다. 위와 같은 경우에는 tmpString을 쓰는 코드가 없으면 제거되었을 가능성이 큽니다. (참고로, IL 코드 자체가 릴리즈 모드로 나오는 경우와 JIT 컴파일에서 다시 최적화를 하는 경우 등 다양하게 있습니다. 처음부터 디버깅하는 경우에는 JIT 컴파일 측에서는 최적화를 안하는 등의... 복잡한 사연이 있습니다.)

이미 릴리즈 빌드로 IL 코드가 제거된 경우라면 어쩔 수 없지만, 그렇지 않고 JIT 컴파일 단계에서 제거되는 경우라면 COMPLUS_ZapDisable 옵션을 두는 것으로 임시로 해결할 수는 있습니다. (혹시나, 켜둔 이후에 사용을 끝내면 운영 서버에서는 반드시 Off 시켜주는 것을 잊지 마세요. ^^)

COMPLUS_ZapDisable - JIT 최적화 코드 생성 제어
; http://www.sysnet.pe.kr/Default.aspx?mode=2&sub=0&detail=1&wid=646

-------

또는, 정확하지 않은 PDB 파일이 로드되었을 때 그럴 수 있습니다. "Modules" 윈도우를 통해 정확한 PDB 파일이 올라왔는지 검사해 보세요.
kevin25

... 46  47  48  49  50  [51]  52  53  54  55  56  57  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
1556김응규4/22/201512234    답변글 [답변]: WCF net.tcp 관련해서 질문 드립니다. [1]파일 다운로드1
1554(삭제)4/19/201512995안드로이드 에뮬레이터에서 특정 앱 구동불가할때! [2]
1552spow...4/18/201518914마이크로세컨드 단위의 Sleep이 필요한데 찾질 못하겠습니다. [5]
1553spow...4/18/201512177    답변글 [답변]: 마이크로세컨드 단위의 Sleep이 필요한데 찾질 못하겠습니다. [1]
1551인디언기...4/16/201511579iisnode에 대해서 글 올리셨던데 질문이 있습니다 [1]
1549김선아4/15/201512031.net framework 4.5와 c++ dll에 관한 질문입니다 [1]
1550김선아4/15/201510447    답변글 [답변]: .net framework 4.5와 c++ dll에 관한 질문입니다 [2]
1547문명식4/3/201512464IWebBrowser Key Event 관련 [2]
1545나종식3/25/201511468internet explorer dns cache flush [2]
1543이용원3/23/201511438hyper-v 질문드려요! [1]
1544이용원3/24/201510570    답변글 한가지만 더 여쭤볼게요! [1]
1541임기성3/20/201517794Microsoft.Office.Core dll관련 문제 [1]
1539펜플3/17/201511127asp.net 질문입니다. [1]
1540113/17/201511118    답변글 [답변]: asp.net 질문입니다. [1]
1538열공합시닷3/13/201511896중계서버 질문드립니다 [1]
1537김재영3/11/201512959asp.net의 빌드 유휴시간 이후의 리빌드 작업을 컨트롤 할 수 있습니까? [2]
1536솔솔3/9/201511411mac address얻으려고 하는데요.. [1]
1535Stud...3/4/201511949C#엔 MFC의 theApp 과 같은 기능을 하는것이 없나요? [3]
1534김동진3/4/201511389C#에서 BHO로 Windows Explorer에서의 동작이 가능할지요 [2]
1533김동현3/3/201511669컴파일 된 프로그램에 코드 삽입(?) 관련입니다. [1]
1532반가워요3/3/201514268C# 소켓연결에 packet송수신... [8]
1531강현수3/2/201512918C# com 등록 시 GUID 변경 관련 문의 [1]
1529김민규2/15/201512800C++ 64bit/32bit [3]파일 다운로드1
1528김개똥2/14/201510288좀 관련없는 질문이지만, 정말 답답하고 찾는데 명확한 해답 찾지못해 질문 올립니다. <Windows 사용자 인증> [1]
1527방문자1/27/201511332System Timer의 Tick에서 Backgroundworker를 호출하면 스레드 문제가 있을까요? [1]
1526황상대1/26/201513155C# 마샬링 관련 질문이 있습니다. [1]
... 46  47  48  49  50  [51]  52  53  54  55  56  57  58  59  60  ...