Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

.NET Reflector - PDB 생성 화면에서 "Clear Store"를 하면 "Index and length must refer to a location within the string" 예외 발생

예전에 소스 코드가 없는 닷넷 어셈블리에 대한 디버깅을 소개했는데요.

.NET Reflector를 이용한 "소스 코드가 없는" 어셈블리 디버깅
; https://www.sysnet.pe.kr/2/0/1201

며칠 전에 저 기능이 필요해서 Visual Studio의 ".NET Reflector" / "Generate PDBs..." 메뉴를 선택해 뜬 창에서 "Clear Store" 버튼을 누르니 다음과 같은 예외가 발생했습니다.

net_reflector_clear_cache_ex_1.png

.NET Reflector has just thrown an exception: Index and length must refer to a location within the string.
Parameter name: length

System.ArgumentOutOfRangeException occurred
Message: Exception thrown: 'System.ArgumentOutOfRangeException' in mscorlib.dll
Additional information: Index and length must refer to a location within the string.

이 뿐만 아니라, 특정 어셈블리를 선택하고 PDB를 생성하려고 하면 100%까지 진행 후 마지막 즈음에 역시 동일한 예외가 발생합니다.

net_reflector_clear_cache_ex_2.png

문제는, 이렇게 한 다음 PDB를 이용한 소스 코드 디버깅을 하려면 다음의 메시지와 함께,

C:\WINDOWS\Microsoft.Net\assembly\GAC_32\mscorlib\v4.0_4.0.0.0__b77a5c561934e089\mscorlib.dll: Cannot find or open the PDB file.

mscorlib.dll 내부의 코드로 디버깅 진입이 안된다는 점입니다. 원인이 뭘까요? ^^ 실제로 PDB 파일을 찾는 경로를 확인해 보면,

PDB Symbol 로드 오류 - Cannot find or openthe PDB file.
; https://www.sysnet.pe.kr/2/0/987

다음과 같이 나오는데,

C:\ConsoleApplication1\ConsoleApplication1\bin\x86\Debug\mscorlib.pdb: Cannot find or open the PDB file.
C:\WINDOWS\Microsoft.Net\assembly\GAC_32\mscorlib\v4.0_4.0.0.0__b77a5c561934e089\mscorlib.pdb: Cannot find or open the PDB file.
C:\WINDOWS\mscorlib.pdb: Cannot find or open the PDB file.
C:\WINDOWS\symbols\dll\mscorlib.pdb: Cannot find or open the PDB file.
C:\WINDOWS\dll\mscorlib.pdb: Cannot find or open the PDB file.
%LOCALAPPDATA%\Temp\SymbolCache\mscorlib.pdb\bec17127f5324ae795428e84a11901182\mscorlib.pdb: Cannot find or open the PDB file.
%LOCALAPPDATA%\Temp\SymbolCache\MicrosoftPublicSymbols\mscorlib.pdb\bec17127f5324ae795428e84a11901182\mscorlib.pdb: Cannot find or open the PDB file.

분명히 저 경로에는 .NET Reflector가 생성한 PDB 파일이 없습니다. 왜냐하면, "Generate PDBs..."로 선택한 .pdb 파일들은 다음의 경로 하위에 저장되기 때문입니다.

%LOCALAPPDATA%\Red Gate\.NET Reflector 9\Cache

해결책은 간단합니다. 생성된 PDB 파일을 검색 경로에 복사해 주거나, 아니면 Visual Studio에서 특정 폴더를 찾으라고 설정해 두면 됩니다. 일단, 제가 생성한 mscorlib.pdb 파일은 검색해 보니 다음의 경로에 놓여 있었습니다.

%LOCALAPPDATA%\Red Gate\.NET Reflector 9\Cache\1

그래서 저 경로를 "Debug" / "Options..." 메뉴를 선택해 "Debugging" / "Symbols"에 등록했습니다.

net_reflector_clear_cache_ex_3.png

이후 디버깅으로 진입해 소스 코드로 F11(Step-into) 기능으로 들어가면 끝!

정리해 보면, PDB 생성 후 예외가 발생한 것은 바로 저 "Debugging" / "Symbols"에 .NET Reflector가 생성한 PDB 경로를 등록하려고 하는데 그게 실패하는 바람에 나타난 것으로 보입니다.




참고로, "%LOCALAPPDATA%\Red Gate\.NET Reflector 9\Cache\1" 경로에서 끝의 숫자 "1"은 자신의 환경에 따라서 바뀔 수 있습니다. 예를 들어, mscorlib.dll의 경우 32비트와 64비트가 따로 있는데 각각의 숫자에 해당하는 폴더로 나뉘어 들어가므로 그에 맞게 적절한 설정을 해야 합니다.




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







[최초 등록일: ]
[최종 수정일: 8/29/2016]

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

비밀번호

댓글 작성자
 




... 106  107  108  109  110  111  112  113  114  115  116  117  118  [119]  120  ...
NoWriterDateCnt.TitleFile(s)
11041정성태9/10/201623585.NET Framework: 605. CLR4 보안 - yield 구문 내에서 SecurityCritical 메서드 사용 불가 - 2번째 이야기
11040정성태9/10/201631252.NET Framework: 604. C# Windows Forms - Drag & Drop 예제 코드 [2]파일 다운로드1
11039정성태9/9/201625733오류 유형: 355. Visual Studio 빌드 오류 - error CS0122: '__ComObject' is inaccessible due to its protection level
11038정성태9/9/201629528VC++: 99. 서로 다른 프로세스에서 WM_DROPFILES 메시지를 전송하는 방법파일 다운로드1
11037정성태9/8/201632769.NET Framework: 603. socket - shutdown 호출이 필요한 사례파일 다운로드1
11036정성태8/29/201627816개발 환경 구성: 297. 소스 코드가 없는 닷넷 어셈블리를 디버깅할 때 지역 변숫값을 확인하는 방법
11035정성태8/29/201623692오류 유형: 354. .NET Reflector - PDB 생성 화면에서 "Clear Store"를 하면 "Index and length must refer to a location within the string" 예외 발생
11034정성태8/25/201627720개발 환경 구성: 296. .NET Core 프로젝트를 NuGet Gallery에 배포하는 방법 [2]
11033정성태8/24/201625786오류 유형: 353. coreclr 빌드 시 error C3249: illegal statement or sub-expression for 'constexpr' function
11032정성태8/23/201624988개발 환경 구성: 295. 최신의 Visual C++ 컴파일러 도구를 사용하는 방법 [1]
11031정성태8/23/201620656오류 유형: 352. Error encountered while pushing to the remote repository: Response status code does not indicate success: 403 (Forbidden).
11030정성태8/23/201624810VS.NET IDE: 111. Team Explorer - 추가한 Git Remote 저장소가 Branch에 보이지 않는 경우
11029정성태8/18/201632488.NET Framework: 602. Process.Start의 cmd.exe에서 stdin만 redirect 하는 방법 [1]파일 다운로드1
11028정성태8/15/201624154오류 유형: 351. Octave 설치 시 JRE 경로 문제
11027정성태8/15/201626704.NET Framework: 601. ElementHost 컨트롤의 메모리 누수 현상
11026정성태8/13/201627850Math: 19. 행렬 연산으로 본 해밍코드
11025정성태8/12/201627461개발 환경 구성: 294. .NET Core 프로젝트에서 "Copy to Output Directory" 처리 [1]
11024정성태8/12/201625857오류 유형: 350. "nProtect GameMon" 실행 중에는 Visual Studio 디버깅이 안됩니다! [1]
11023정성태8/10/201627606개발 환경 구성: 293. Azure 구독 후 PaaS 서비스 만들어 보기
11022정성태8/10/201628005개발 환경 구성: 292. Azure Cloud Service 배포시 사용자 정의 작업을 추가하는 방법
11021정성태8/10/201625460오류 유형: 349. System.Runtime.Remoting.RemotingException - Type '..., ..., Version=..., Culture=neutral, PublicKeyToken=null' is not registered for activation [2]
11020정성태8/10/201628351VC++: 98. 원본과 대상 버퍼가 같은 경우 memcpy, wmemcpy 주의점
11019정성태8/10/201645244기타: 60. 도서: 시작하세요! C# 6.0 프로그래밍: 기본 문법부터 실전 예제까지 (2쇄 정오표)
11018정성태8/9/201629016.NET Framework: 600. 단일 메서드 내에서의 할당으로 알아보는 자바와 닷넷의 GC 차이점 [1]
11017정성태8/9/201629817웹: 33. HTTP 쿠키에 한글 값을 설정하는 방법
11016정성태8/7/201628210개발 환경 구성: 291. Windows Server Containers 소개
... 106  107  108  109  110  111  112  113  114  115  116  117  118  [119]  120  ...