Microsoft MVP성태의 닷넷 이야기
디버깅 중 이해할 수 없는 상황이 [링크 복사], [링크+제목 복사],
조회: 18467
글쓴 사람
임동찬 (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

... 16  17  18  19  20  21  22  23  24  [25]  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5331sdd5/13/202014955안녕하세요 Settings관련하여 질문드립니다. [2]파일 다운로드1
5330하태5/7/202019951안녕하세요! 질문 드리겠습니다! C# dll에서 c++ CLR프로젝트를 참조 추가 할 수 있나요? [2]
5329김태령4/21/202014594젠킨스에서 원격 머신에 있는 실행 파일을 실행하면 백그라운드로 뜹니다 [2]
5328crea...4/17/202014637안녕하세요! [3]파일 다운로드1
5327김동욱4/17/202015778HttpListener 사용시 HTTP/2 질문입니다. [2]
5323나그네4/15/202014973해결 115p 네임스페이스의 ConsoleApp1.exe는 netcoreapp3.1 폴더에 있었습니다. [1]파일 다운로드1
5322나그네4/14/202014783질문 115p 네임스페이스의 ConsoleApp1.exe 컴파일 또는 빌드방법 [2]파일 다운로드1
5321나그네4/14/202016866오타인가요? [2]
5320kiki...4/10/202020196C# Serial 통신 관련 질문 입니다. [5]
5319권대현4/10/202015190C++(UWP)Dll에서 C#(UWP)Dll 호출이 가능한가요? [1]
5318이승준4/9/202016447동영상 관련 업계 근황? 입니다. [1]
5317kskk...4/7/202018633OpenCV 이용 해상도 설정 질문 입니다.. [3]
5316윤현수4/7/202015113pipe 비동기방식 질문 [1]파일 다운로드1
53154/6/202015799dll파일 로드 원리? 부분에서 도움받고싶습니다. [3]
5314강성욱3/31/202018385메서드 내에서 await 2번 등장할 때의 이해 [11]파일 다운로드1
5313강성욱3/27/202015928await 2번 [1]
53121a2a...3/20/202014699Re raw data write 질문 관련 [1]파일 다운로드1
53111a2a...3/20/202017116Raw data write 관련 질문 [1]파일 다운로드1
5310아스파넬3/15/2020169741초에 5회 함수호출 제한 관련 질문입니다. [1]
5309하태3/11/202018900안녕하십니까. c# Winform UI 질문드리겠습니다! [3]파일 다운로드1
5308질문3/9/202017765Window XP SP3 32bit 환경(Window Update 모두 완료)에서 .Net Framework 4.0.3 으로 빌드된 .dll 파일 gacutil.exe 등록 관련 문의 [5]
5306개발자3/9/202017136C#을 통해 인터넷 접속 가능한 이더넷을 선택할 수 있는지요? [1]
5305JaeS...3/9/202015616RAW파일 생성 질문드립니다 [8]파일 다운로드1
5303궁금하당2/27/202018758C#에서 C++ DLL읽기 (아래 글쓴이) [1]
5302궁금하당2/27/202020738C#에서 C++ DLL호출 ('PInvokeStackImbalance') [4]파일 다운로드1
5301질문합니...2/27/202015320소켓 대량 데이터 디자인 문의 [1]
... 16  17  18  19  20  21  22  23  24  [25]  26  27  28  29  30  ...