当前位置:网站首页>如何使用windbg查看C#某个线程的栈大小 ?
如何使用windbg查看C#某个线程的栈大小 ?
2022-08-02 20:02:00 【biyusr】
每一个线程都有一个叫 TEB(Thread Environment Block) 的线程环境块数据结构,这个结构中有一个叫做 NT_TIB 的结构,它里面有两个字段分别为 StackBase 和 StackLimit,前面叫做栈基址,也就是栈顶,后者叫做 栈边界 ,因为栈空间是向小地址增长的,所以用 StackBase - StackLimit 就能算出所谓的栈内存大小,接下来我们用 windbg 演示一下。
一:windbg 演示
1. 使用 !teb 命令
大家可以用 windbg 直接调试你的程序,我手里刚好有一个 dump 文件,这里就从主线程看起吧。
0:000> ~0s
ntdll!NtWaitForSingleObject+0x14:
00007ffe`28b9fa74 c3 ret
0:000> !teb
TEB at 000000b4da0ae000
ExceptionList: 0000000000000000
StackBase: 000000b4d9fa0000
StackLimit: 000000b4d9f98000
SubSystemTib: 0000000000000000
FiberData: 0000000000001e00
ArbitraryUserPointer: 0000000000000000
Self: 000000b4da0ae000
EnvironmentPointer: 0000000000000000
ClientId: 0000000000000c74 . 00000000000041a4
RpcHandle: 0000000000000000
Tls Storage: 000001f90edad1d0
PEB Address: 000000b4da0ad000
LastErrorValue: 0
LastStatusValue: 103
Count Owned Locks: 0
HardErrorMode: 0
从输出看两个值分别为:StackBase=000000b4d9fa0000 和 StackLimit=000000b4d9f98000,那它的大小就是 32768byte = 32k。
0:000> ? 000000b4d9fa0000 - 000000b4d9f98000
Evaluate expression: 32768 = 00000000`00008000
这里要提醒一下,操作系统的内存页是 4k 为一个粒度,也就说所有的输出结果肯定是4k的倍数,比如当前栈空间就是 8 个内存页。
2. 查看 NT_TIB 结构
刚才用的是快捷命令,接下来我们直接查看 _TEB 结构下的 NT_TIB struct 结构变量。
0:000> .thread
Implicit thread is now 000000b4`da0ae000
0:000> dt _NT_TIB 000000b4`da0ae000
combase!_NT_TIB
+0x000 ExceptionList : (null)
+0x008 StackBase : 0x000000b4`d9fa0000 Void
+0x010 StackLimit : 0x000000b4`d9f98000 Void
+0x018 SubSystemTib : (null)
+0x020 FiberData : 0x00000000`00001e00 Void
+0x020 Version : 0x1e00
+0x028 ArbitraryUserPointer : (null)
+0x030 Self : 0x000000b4`da0ae000 _NT_TIB
可以看到,上面的两个值和 !teb 显示的一模一样。
边栏推荐
- pytorch的tensor创建和操作记录
- Helm基础知识
- shell:条件语句
- J9 digital theory: the Internet across chain bridge has what effect?
- arm64麒麟安装paddlehub(国产化)
- js Fetch返回数据res.json()报错问题
- 二丙二醇甲醚醋酸酯
- 4 kmiles join YiSheng group, with more strong ability of digital business, accelerate China's cross-border electricity full domain full growth
- TodoList案例
- SQL Server安装教程
猜你喜欢
随机推荐
即时通讯开发移动端网络短连接的优化手段
【SLAM】DM-VIO(ros版)安装和论文解读
笑话:如果你在河边等待得足够久,你会看到你的敌人的尸体漂过,是怎么翻译出来的?
牛客题目——滑动窗口的最大值、矩阵最长递增路径、顺时针旋转矩阵、接雨水问题
【LeetCode】622. 设计循环队列
Fetch 请求不转换BLOB正常显示GBK编码的数据
软件测试分类
二丙二醇甲醚醋酸酯
APP自动化uiautomator2获取toast
ECCV 2022 | 通往数据高效的Transformer目标检测器
Helm基础知识
基于 flex 布局实现的三栏布局
Electron User Guide Beginning Experience
golang源码分析之geoip2-golang
SQL Server数据类型转换函数cast()和convert()详解
基本语法(三)
golang源码分析:time/rate
Caldera(一)配置完成的虚拟机镜像及admin身份简单使用
姑姑:给小学生出点口算题
【LeetCode】1161. 最大层内元素和









