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

비밀번호

댓글 작성자
 




... 181  182  183  184  185  186  187  [188]  189  190  191  192  193  194  195  ...
NoWriterDateCnt.TitleFile(s)
254정성태6/1/200617607개발 환경 구성: 2. VPC에 Vista 설치하는 방법 [2]
255정성태6/1/200617361    답변글 개발 환경 구성: 2.1. msconfig 설정과 Windows Activation
259정성태6/1/200616447    답변글 개발 환경 구성: 2.2. Vista VPC에 터미널 서비스 - 원격 접속
253정성태6/1/200614720기타: 14. .NET 2.0 이 지원되는 NDoc 2.0 을 배포합니다.
251정성태6/1/200617778오류 유형: 4. [OS 지원 API] SHParseDisplayName과 Windows 2000
252정성태6/1/200617547    답변글 오류 유형: 4.1. NET BCL 에서 제공되는 FolderBrowserDialog [2]
249정성태6/1/200617024.NET Framework: 71. VB.NET 이외의 언어에서 My 네임스페이스 사용
250정성태6/1/200619688    답변글 .NET Framework: 71.1. VB.NET 이외의 언어에서 My 네임스페이스 사용
248정성태6/1/200617865기타: 13. Code Center Premium에서 Win32 API 소스 찾기
245정성태6/1/200625466오류 유형: 3. [C# / VC++] error C2146: syntax error : missing ';' before identifier 'GetType'
247정성태5/3/200622714    답변글 .NET Framework: 3.1. Interface를 사용하면. [1]
242정성태6/1/200623203오류 유형: 2. [COM+] CreateObject 와 HTTP 500 - Internal server error
243정성태6/1/200620718    답변글 오류 유형: 2.1. [COM+] Resolve Partial Assembly failed for Microsoft.VC80.CRT.mui
244정성태6/1/200621952    답변글 오류 유형: 2.2. [COM+] Server object error 'ASP 0178 : 80070005'
240정성태6/1/200619855스크립트: 9. setTimeout 과 jscript/vbscript 혼용 문제
239정성태6/1/200621121COM 개체 관련: 18. Internet Explorer는 Out-of-process COM 개체입니다.
238정성태6/1/200622962개발 환경 구성: 1. batch 파일에서 실행한 exe에서 batch 실행 문맥의 환경 변수 설정 [3]
236정성태6/1/200643762오류 유형: 1. [.NET COM+] UnauthorizedAccessException: 레지스트리 키 HKEY_CLASSES_ROOT\.... 에 대한 액세스가 거부되었습니다
235정성태6/1/200618405VS.NET IDE: 39. VS.NET 2003/2005에서도 제공되는 VS 6.0 MFC ClassWizard
234정성태4/14/200618144VC++: 24. error C2039: 'pOleStr' : is not a member of '_STRRET'
233정성태4/13/200617505.NET Framework: 70. Response.ContentType 과 Response.AddHeader( "Content-Type", "..." ) 의 차이
232정성태4/13/200617264.NET Framework: 69. Reusing C# Source Code Across Multiple Assemblies
231정성태4/13/200617681Team Foundation Server: 4. How to rename a Team Foundation Server
229정성태10/17/200619214.NET Framework: 68. Feb CTP 에서 동작하는 "Save XPS Document page(s) to .bmp" 예제 소스
230정성태4/13/200619507    답변글 .NET Framework: 68.1. -01 MSDN Magazine XPS Document 소스를 Feb CTP로 수정한 버전파일 다운로드1
228정성태4/13/200615903Team Foundation Server: 3. MSBUILD : warning : Visual Studio Team System for Software Testers or Visual Studio Team System for Software Developers is required to run tests as part of a Team Build.
... 181  182  183  184  185  186  187  [188]  189  190  191  192  193  194  195  ...