Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)

Visual Studio - Memory 창에서 유효한 주소 영역임에도 "Unable to evaluate the expression." 오류 출력

Visual Studio에서 메모리 덤프 파일을 열어 disassembly 창을 보던 중,

00007FFC9973EAD2 57                   push        rdi  
00007FFC9973EAD3 41 56                push        r14  
...[생략]...
00007FFC9973EB33 48 8D 45 90          lea         rax,[rbp-70h]  
00007FFC9973EB37 48 89 47 10          mov         qword ptr [rdi+10h],rax  
00007FFC9973EB3B C6 47 0C 00          mov         byte ptr [rdi+0Ch],0  
00007FFC9973EB3F FF 15 0B 78 AB FF    call        qword ptr [7FFC991F6350h]  
00007FFC9973EB45 C6 47 0C 01          mov         byte ptr [rdi+0Ch],1  
...[생략]...
00007FFC9973EB74 C3                   ret  

7FFC991F6350h 주소에 담긴 값이 궁금해 메모리 창(Ctrl + Alt + M, 1)을 열어 입력했으나,

unable_to_eval_in_vs_mem_1.png

Unable to evaluate the expression.

저렇게 오류가 발생합니다. 확실한 것은 아닌데, 경험 상 2개 이상의 메모리 덤프 파일을 각각 비주얼 스튜디오로 열어 분석할 때 이런 현상이 자주 일어나는 것 같습니다. 실제로, 위와 같은 메시지가 나타나도 비주얼 스튜디오를 종료 후 다시 실행해 메모리 창을 보면 정상적으로 값이 나옵니다.

따라서, 덤프 파일에는 이상이 없는 것이므로 만약 디버깅 중인 비주얼 스튜디오를 종료하고 싶지 않다면 별도의 windbg 등의 디버거를 띄워 같은 메모리 덤프 파일을 열어 조사해 보면,

0:042> dq 0x7FFC991F6350
00007ffc`991f6350  00007ffd`0390b790 00000000`00000000
00007ffc`991f6360  00007ffc`9903da50 00000000`00000000
00007ffc`991f6370  00007ffc`9903da60 00000000`00000000
00007ffc`991f6380  00007ffc`9903da70 00000000`00000000
00007ffc`991f6390  00007ffc`9903da80 00000000`00000000
00007ffc`991f63a0  00007ffc`9903da90 00000000`00000000
00007ffc`991f63b0  00007ffc`9903daa0 00000000`00000000
00007ffc`991f63c0  00007ffc`9903dab0 00000000`00000000

정상적으로 값을 확인할 수 있습니다.




이와 마찬가지로, 메모리 창뿐만 아니라 "Disassembly" 창에서도 유효한 코드 주소인데도 다음과 같은 식으로 오류가 발생하는 경우가 있습니다.

The specified address cannot be displayed. error CS0518: Predefined type 'System.Void' is not defined or imported.

이럴 때도 그냥 windbg를 함께 열어 "u" 명령어를 이용해 코드를 확인하면 됩니다. (또는 비주얼 스튜디오를 재시작하든가.)

0:042> u 0x00007ffd0390b790
combase!CoTaskMemFree [d:\rs1\onecore\com\combase\class\memapi.cxx @ 467]:
00007ffd`0390b790 4883ec28        sub     rsp,28h
00007ffd`0390b794 488b05055b2100  mov     rax,qword ptr [combase!g_CMalloc (00007ffd`03b212a0)]
00007ffd`0390b79b 488d15eed40400  lea     rdx,[combase!CRetailMalloc_Free (00007ffd`03958c90)]
00007ffd`0390b7a2 488b4028        mov     rax,qword ptr [rax+28h]
00007ffd`0390b7a6 483bc2          cmp     rax,rdx
00007ffd`0390b7a9 7521            jne     combase!CoTaskMemFree+0x3c (00007ffd`0390b7cc)
00007ffd`0390b7ab 4885c9          test    rcx,rcx
00007ffd`0390b7ae 7417            je      combase!CoTaskMemFree+0x37 (00007ffd`0390b7c7)




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 11/18/2019]

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

비밀번호

댓글 작성자
 




... [31]  32  33  34  35  36  37  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
12854정성태11/13/20217790개발 환경 구성: 604. Azure - 윈도우 VM에서 FTP 여는 방법
12853정성태11/10/20216141오류 유형: 766. Azure App Service - JBoss 호스팅 생성 시 "This region has quota of 0 PremiumV3 instances for your subscription. Try selecting different region or SKU."
12851정성태11/1/20217535스크립트: 34. 파이썬 - MySQLdb 기본 예제 코드
12850정성태10/27/20218683오류 유형: 765. 우분투에서 pip install mysqlclient 실행 시 "OSError: mysql_config not found" 오류
12849정성태10/17/20217792스크립트: 33. JavaScript와 C#의 시간 변환 [1]
12848정성태10/17/20218783스크립트: 32. 파이썬 - sqlite3 기본 예제 코드 [1]
12847정성태10/14/20218644스크립트: 31. 파이썬 gunicorn - WORKER TIMEOUT 오류 발생
12846정성태10/7/20218393스크립트: 30. 파이썬 __debug__ 플래그 변수에 따른 코드 실행 제어
12845정성태10/6/20218225.NET Framework: 1120. C# - BufferBlock<T> 사용 예제 [5]파일 다운로드1
12844정성태10/3/20216236오류 유형: 764. MSI 설치 시 "... is accessible and not read-only." 오류 메시지
12843정성태10/3/20216682스크립트: 29. 파이썬 - fork 시 기존 클라이언트 소켓 및 스레드의 동작파일 다운로드1
12842정성태10/1/202125029오류 유형: 763. 파이썬 오류 - AttributeError: type object '...' has no attribute '...'
12841정성태10/1/20218507스크립트: 28. 모든 파이썬 프로세스에 올라오는 특별한 파일 - sitecustomize.py
12840정성태9/30/20218606.NET Framework: 1119. Entity Framework의 Join 사용 시 다중 칼럼에 대한 OR 조건 쿼리파일 다운로드1
12839정성태9/15/20219655.NET Framework: 1118. C# 11 - 제네릭 타입의 특성 적용파일 다운로드1
12838정성태9/13/20219299.NET Framework: 1117. C# - Task에 전달한 Action, Func 유형에 따라 달라지는 async/await 비동기 처리 [2]파일 다운로드1
12837정성태9/11/20218209VC++: 151. Golang - fmt.Errorf, errors.Is, errors.As 설명
12836정성태9/10/20217815Linux: 45. 리눅스 - 실행 중인 다른 프로그램의 출력을 확인하는 방법
12835정성태9/7/20219065.NET Framework: 1116. C# 10 - (15) CallerArgumentExpression 특성 추가 [2]파일 다운로드1
12834정성태9/7/20217450오류 유형: 762. Visual Studio 2019 Build Tools - 'C:\Program' is not recognized as an internal or external command, operable program or batch file.
12833정성태9/6/20216902VC++: 150. Golang - TCP client/server echo 예제 코드파일 다운로드1
12832정성태9/6/20217762VC++: 149. Golang - 인터페이스 포인터가 의미 있을까요?
12831정성태9/6/20216293VC++: 148. Golang - 채널에 따른 다중 작업 처리파일 다운로드1
12830정성태9/6/20218559오류 유형: 761. Internet Explorer에서 파일 다운로드 시 "Your current security settings do not allow this file to be downloaded." 오류
12829정성태9/5/202110193.NET Framework: 1115. C# 10 - (14) 구조체 타입에 기본 생성자 정의 가능파일 다운로드1
12828정성태9/4/20218325.NET Framework: 1114. C# 10 - (13) 단일 파일 내에 적용되는 namespace 선언파일 다운로드1
... [31]  32  33  34  35  36  37  38  39  40  41  42  43  44  45  ...