Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)
(시리즈 글이 5개 있습니다.)
디버깅 기술: 112. windbg - 닷넷 메모리 덤프에서 전역 객체의 내용을 조사하는 방법
; https://www.sysnet.pe.kr/2/0/11460

디버깅 기술: 115. windbg - 닷넷 메모리 덤프에서 정적(static) 필드 값을 조사하는 방법
; https://www.sysnet.pe.kr/2/0/11487

.NET Framework: 957. C# - static 필드의 정보가 GC Heap에 저장될까요?
; https://www.sysnet.pe.kr/2/0/12387

디버깅 기술: 182. windbg - 닷넷 메모리 덤프에서 AppDomain에 걸친 정적(static) 필드 값을 조사하는 방법
; https://www.sysnet.pe.kr/2/0/13004

디버깅 기술: 193. Windbg - ThreadStatic 필드 값을 조사하는 방법
; https://www.sysnet.pe.kr/2/0/13414




windbg - 닷넷 메모리 덤프에서 정적(static) 필드 값을 조사하는 방법

지난번에, singleton을 비롯해 인스턴스화된 객체 값을 조사하는 방법을 설명했는데요.

windbg - 닷넷 메모리 덤프에서 전역 객체의 내용을 조사하는 방법
; https://www.sysnet.pe.kr/2/0/11460

간단하게 다음과 같은 예제 코드를 이용해 테스트할 수 있습니다.

using System;

namespace ConsoleApp1
{
    class Program
    {
        static void Main(string[] args)
        {
            InstanceClass inst = new InstanceClass();
            inst.Count++;
            Console.WriteLine(inst.Count);

            Console.ReadLine(); // 이 시점에 메모리 덤프
        }
    }

    public class InstanceClass
    {
        public int Count;
    }
}

덤프 파일을 windbg에서 열고 지난번 글에서 설명한 대로 InstanceClass 타입의 Count 값을 이렇게 확인하게 됩니다.

0:000> !dumpheap -type ConsoleApp1.InstanceClass
         Address               MT     Size
0000013d93f26ce8 00007ffde3015ab8       24     

Statistics:
              MT    Count    TotalSize Class Name
00007ffde3015ab8        1           24 ConsoleApp1.InstanceClass
Total 1 objects

0:000> !DumpObj /d 0000013d93f26ce8
Name:        ConsoleApp1.InstanceClass
MethodTable: 00007ffde3015ab8
EEClass:     00007ffde3161020
Size:        24(0x18) bytes
File:        E:\ConsoleApp1\ConsoleApp1\bin\Debug\ConsoleApp1.exe
Fields:
              MT    Field   Offset                 Type VT     Attr            Value Name
00007ffe3df69500  4000002        8         System.Int32  1 instance                1 Count

그럼, 이제 위의 예제 코드에 static 필드를 가진 타입을 추가해 보겠습니다.

using System;

namespace ConsoleApp1
{
    class Program
    {
        static void Main(string[] args)
        {
            StaticClass.Count++;
            Console.WriteLine(StaticClass.Count);

            InstanceClass inst = new InstanceClass();
            inst.Count++;
            Console.WriteLine(inst.Count);

            Console.ReadLine();
        }
    }

    public class StaticClass
    {
        public static int Count;
    }

    public class InstanceClass
    {
        public int Count;
    }
}

당연하겠지만, StaticClass 클래스의 Count 값은 dumpheap으로는 알 수 없습니다. 심지어, 위의 경우에는 인스턴스화 한 적도 없기 때문에 dumpheap으로는 기록조차 찾을 수 없습니다.

0:000> !dumpheap -type ConsoleApp1.StaticClass
         Address               MT     Size

Statistics:
              MT    Count    TotalSize Class Name
Total 0 objects

new를 했어야 Managed Heap에 기록이 남기 때문에 위의 결과는 지극히 정상적인 것입니다. 대신, static 필드의 값은 클래스 정보를 통해 알아낼 수 있습니다. 이를 위해 다음과 같이 클래스의 식별자를 알아내고,

0:000> !name2ee ConsoleApp1.exe!ConsoleApp1.StaticClass
Module:      00007ffde3014110
Assembly:    ConsoleApp1.exe
Token:       0000000002000003
MethodTable: 00007ffde3015b68
EEClass:     00007ffde3161098
Name:        ConsoleApp1.StaticClass

그에 대해 DumpClass 명령을 내리면 됩니다.

0:000> !DumpClass /d 00007ffde3161098
Class Name:      ConsoleApp1.StaticClass
mdToken:         0000000002000003
File:            E:\ConsoleApp1\ConsoleApp1\bin\Debug\ConsoleApp1.exe
Parent Class:    00007ffe3d8d1968
Module:          00007ffde3014110
Method Table:    00007ffde3015b68
Vtable Slots:    4
Total Method Slots:  5
Class Attributes:    100001  
Transparency:        Critical
NumInstanceFields:   0
NumStaticFields:     1
              MT    Field   Offset                 Type VT     Attr            Value Name
00007ffe3df69500  4000001       3c         System.Int32  1   static                1 Count




참고로, 타입 이름을 기준으로 하는 "!dumpheap -type ConsoleApp1.InstanceClass" 명령어로 관리 힙을 검색하는 것은 경우에 따라 불편함이 있습니다. 왜냐하면, 검색어로 준 "ConsoleApp1.InstanceClass" 이름과 정확히 일치하는 것이 아니라 그것을 포함하고 있어도 검색이 되기 때문입니다.

따라서, 해당 타입에 대해 정확히 일치하는 것만 검색하고 싶다면 name2ee 명령을 통해 우선 그 타입의 MethodTable을 얻는 것이 좋습니다.

0:017> !name2ee *!ConsoleApp1.InstanceClass
Module: 02d32010 (teslib.dll)
Token: 0x02000154
MethodTable: 043117dc
EEClass: 02db3280
Name: ConsoleApp1.InstanceClass

이렇게 알아낸 MethodTable로 dumpheap 검색을 하면 됩니다.

0:017> !DumpHeap -mt  043117dc




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 4/17/2025]

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)
10974정성태5/20/201623592.NET Framework: 588. C# - OxyPlot 라이브러리로 복소수 표현파일 다운로드1
10973정성태5/20/201628684.NET Framework: 587. C# Plotting 라이브러리 OxyPlot [3]파일 다운로드1
10972정성태5/19/201627627Math: 16. C# - 갈루아 필드 GF(2) 연산 [3]파일 다운로드1
10971정성태5/19/201620485오류 유형: 334. Visual Studio - 빌드 시 경고 warning MSB3884: Could not find rule set file "...". [2]
10970정성태5/19/201624867오류 유형: 333. OxyPlot 라이브러리의 컨트롤을 Toolbox에 등록 시 오류 [2]
10969정성태5/18/201624179.NET Framework: 586. C# - 파일 확장자에 연결된 프로그램을 등록하는 방법 (3) - "Open with" 목록에 등록파일 다운로드1
10968정성태5/18/201619169오류 유형: 332. Visual Studio - 단위 테스트 생성 시 "Design time expression evaluation" 오류 메시지
10967정성태5/12/201624297.NET Framework: 585. C# - 파일 확장자에 연결된 프로그램을 등록하는 방법 (2) - 웹 브라우저가 다운로드 후 자동 실행
10966정성태5/12/201631943.NET Framework: 584. C# - 파일 확장자에 연결된 프로그램을 등록하는 방법 (1) - 기본 [1]파일 다운로드1
10965정성태5/12/201623985디버깅 기술: 81. try/catch로 조용히 사라진 예외를 파악하고 싶다면?
10964정성태5/12/201622575오류 유형: 331. ASP.NET에서 System.BadImageFormatException 예외가 발생하는 경우
10963정성태5/11/201624800VS.NET IDE: 107. Visual Studio 2015의 "DTAR_..." 특수 폴더가 생성되는 문제파일 다운로드2
10962정성태5/11/201624950오류 유형: 330. Visual Studio 단위 테스트 시 DisconnectedContext 예외 발생
10961정성태5/11/201624757.NET Framework: 583. 문제 재현 - Managed Debugging Assistant 'DisconnectedContext' has detected a problem in '...'파일 다운로드1
10960정성태5/10/201622153오류 유형: 329. ATL 메서드 추가 마법사 창에서 8ce0000b 오류 발생
10959정성태5/9/201624801.NET Framework: 582. CLR Profiler - 별도 정의한 .NET 코드를 호출하도록 IL 코드 변경파일 다운로드1
10958정성태5/6/201651820개발 환경 구성: 284. "Let's Encrypt"에서 제공하는 무료 SSL 인증서를 IIS에 적용하는 방법 (1) [3]
10957정성태5/3/201627107오류 유형: 328. 윈도우 백업 시 오류 - 0x80780166 두 번째 이야기 [1]
10956정성태5/3/201622628Windows: 117. BitLocker - This device can't use a Trusted Platform Module.
10955정성태5/3/201629285.NET Framework: 581. C# - 순열(Permutation) 예제 코드파일 다운로드2
10954정성태5/3/201630237.NET Framework: 580. C# - 조합(Combination) 예제 코드 [2]파일 다운로드1
10953정성태5/2/201619811.NET Framework: 579. Assembly.LoadFrom으로 로드된 어셈블리의 JIT 컴파일 코드 공유?파일 다운로드1
10952정성태5/2/201621920.NET Framework: 578. 도메인 중립적인 어셈블리가 비-도메인 중립적인 어셈블리를 참조하는 경우파일 다운로드1
10951정성태5/2/201619826.NET Framework: 577. CLR Profiler로 살펴보는 SharedDomain의 모듈 로드 동작파일 다운로드1
10950정성태5/2/201626283.NET Framework: 576. 기본적인 CLR Profiler 소스 코드 설명 [2]파일 다운로드2
10949정성태4/28/201619844.NET Framework: 575. SharedDomain과 JIT 컴파일파일 다운로드1
... 106  107  108  109  110  111  112  113  114  115  116  117  [118]  119  120  ...