博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
初次使用Windbg检查C#程序内存
阅读量:5086 次
发布时间:2019-06-13

本文共 1293 字,大约阅读时间需要 4 分钟。

1. 下载windbg并安装。

我下载的是 Windbg 6.12。注意,windbg分32位和64位,由分析环境的位数决定。我这里安装的是32位的。安装过程很简单,一路next就可以。

2. 准备被调试的程序。

新建一个C#控制台程序,使用如下代码。编译~

class Program    {        static void Main(string[] args)        {            TestClass tref = new TestClass();            Console.ReadKey();        }    }    public class TestClass    {        public int A = 7;        public byte B = 1;        public int C = 8;        public byte D = 2;        public byte E = 3;        public byte F = 4;        public int G = 9;    }
View Code

3. 到bin/debug目录下,运行创建的程序

4. 打开Windbg。

初次使用,需要加载符号文件。选择菜单: File - Symbol File Path,输入:

 srv*d:\SymbolsLocal*http://msdl.microsoft.com/download/symbols 

5. 附件到进程

选择 File - Attach to a process,然后在弹出的窗口中选择我们正在运行的控制台程序

6. 加载 sos 工具

如下图。然后输入 .chain,用于确认sos.dll确实被加载。

7. 获得主线程上的引用

输入命令:  ~0s 

 

8. 输出主线程上的线程栈信息

输入命令  !clsstack -l 。可以看到,main方法有一个局部变量,地址是 0x020c2350

9. 输出局部变量的信息

!dumpobj /d 0x020c2350 。如下图

打印出来的内容:

Name:类名

MethodTable:方法表地址

Size:占用内存空间多少字节

红色框里,是该对象所有字段的详细信息表格,包含每个字段的MT(方法表地址)、Offset(相对偏移量)、类型、VT(=1:值类型,=0:引用类型)、Attr(静态的还是实例的)、字段值、字段名称

注意,在offset中,可以看到每个字段在内存的分布,如下图。

 

这么分布是为了字段对齐。即,CLR为了节省空间,各个字段在内存中,并不是按代码定义的顺序进行分布的,而是把byte字段合到一起,让它们共同占用4个字节。int每个变量占4个字节。就形成了上图的分布。

10. 查看内存情况

选择菜单 View - Memory,在Virtual中输入刚才变量地址,可以验证上面所说的情况

 

转载于:https://www.cnblogs.com/cc299/p/10693508.html

你可能感兴趣的文章
##通讯录阶段重要代码
查看>>
下拉框和搜索输入框的二三事
查看>>
Excel Web App使用说明
查看>>
android Bitmap学习总结
查看>>
ORACLE EXECUTE IMMEDIATE 用法
查看>>
什么是新零售?
查看>>
UED大全
查看>>
电脑右键没有新建选项解决
查看>>
查找树ADT
查看>>
iOS10推送必看UNNotificationServiceExtension
查看>>
验证码问题
查看>>
poj 1696
查看>>
【搞定GTD】用iPhone打造GTD实践1年后的心得体会
查看>>
Spring bean生命周期(一)
查看>>
ELK日志分析平台
查看>>
hightchars插件
查看>>
Android 控件布局常用属性
查看>>
why
查看>>
Access-Control-Max-Age
查看>>
selenium元素定位(Java)
查看>>