简介

高级调试过程中,与线程与线程栈是打交道特别多的。因此如何查看线程与线程栈就显得至关重要了

查看线程

!Threads

使用 !t/!Threads 命令获取所有托管线程

含义
ThreadCount 线程数量
UnstartedThread 线程创建,但未开始的
BackgroundThread 后台线程数量
PendingThread 阻塞的线程数量
DeadThread 线程已经执行完,到被线程池回收的这个过程。线程被称为Dead Thread。此时OSId会被销毁
列名 详细说明
null windbg自定义的线程Id,包含了托管线程和非托管线程。我们可以看到,0之后紧接着就是5.说明有4个非托管线程被创建
Id 托管线程Id,就是CurrentManagedThreadId
OSId 操作系统的Id,CLR团队曾经想将托管线程Id与OSId 设为多对一的关系。并未成功。现在是一对一的关系
ThreadOBJ CLR层面的Thread信息,可以用dp观察其中的内容
State CLR层面的线程状态
GC Mode CLR当前的线程状态,是抢占模式还是协作模式,主要是判断是否有操控托管堆的权限
GC Alloc Context GC会在这个上下文区间内分配对象,类似于缓冲区
Domain 当前线程所属的应用程序域,默认情况为Domain1
Lock Count 当前线程持有的托管锁个数
Apt 当前COM套件模式,分为STA与MTA
Exception 当前线程的异常信息,如果抛出异常并未处理的话

Threads命令包含了一组开关如下

  1. !t -live

只输出处于活跃状态的线程的信息

2. !t -special

额外输出所有“特殊”线程,如垃圾回收线程,线程池线程

查看非托管调用栈

k

WinDbg是非托管调试器,自带的命令k只能查看非托管调用栈。因此看不到托管部分。

会输出如下警告信息:

WARNING:Frame IP not in any known module. Following frames may be wrong.

我并没有复现,可能是版本的windbg有调整。但是红圈部分也表示了。这一段代码并没有pdb文件,所以只显示一个Entry_point

查看托管调用栈

!ClrStack

因此要查看托管代码的调用栈,要使用SOS拓展的ClrStack命令。



ClrStack命令显示了托管调用栈的所有栈帧,并有如下几个开关

  1. !Clrstack -l

    相当于local,用于显示局部变量信息

  2. !Clrstack -p

    相当于parameters将显示调用栈上每个托管代码帧的所有参数

  3. !Clrstack -a

    相当于all,把当前线程上的局部变量和参数全部显示出来

Clrstack命令如果在非托管代码线程上运行,会显示一个错误信息

!dso



有时候我们会发现有很多变量是no data. 尤其是64位程序。

我们可以辅助使用!dso命令来显示出线程调用栈的所有对象

同时查看托管/非托管调用栈

!DumpStack

Clrstack命令只输出托管代码调用栈,k命令只出书非托管调用栈。要同时输出,可以使用dumpstack命令。

使用-EE开关还表示只显示托管函数,这与ClrStack一模一样。只是多显示了方法描述符指针

可能并没有你想象的这么好用,因为输出的信息太多了。反而不利于判断。

遍历所有线程的调用栈

!EEStack

有时候,我们需要获得进程中所有托管线程的调用栈,不想重复使用0s,1s来切换线程。

我们可以使用EEStack命令,来遍历所有托管线程的调用栈,非托管线程不遍历

  1. !EEStack -short

    这个开关只输出"感兴趣"的调用栈,比如当前线程持有一个锁,线程被劫持以执行一个垃圾收集操作,线程正在执行。

  2. !EEStack -EE

    直接传递给DumpStack命令,并只显示托管代码调用栈

~*e xxx

e代表在指定线程后 追加一个指令。

比如 ~*e !clrstack 代表遍历所有托管线程的调用栈

~*e k 代表遍历所有非托管线程的调用栈

总结

.NET高级调试 - 3.8线程操作的更多相关文章

  1. Linux高级调试与优化——gdb调试命令

    番外 2019年7月26日至27日,公司邀请<软件调试>和<格蠹汇编——软件调试案例集锦>两本书的作者张银奎老师进行<Linux高级调试与优化>培训,有幸聆听张老师 ...

  2. (九) 一起学 Unix 环境高级编程 (APUE) 之 线程

    . . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编 ...

  3. (十) 一起学 Unix 环境高级编程 (APUE) 之 线程控制

    . . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编 ...

  4. [Android Studio 权威教程]断点调试和高级调试

    好了开始写一个简单的调试程序,我们先来一个for循环 ? 1 2 3 4 5 6 7 8 <code class="language-java hljs ">for ( ...

  5. ###Android 断点调试和高级调试###

    转自:http://www.2cto.com/kf/201506/408358.html 有人说Android 的调试是最坑的,那我只能说是你不会用而已,我可以说Android Studio的调试是我 ...

  6. 8)Linux程序设计入门--线程操作

    )Linux程序设计入门--线程操作 前言:Linux下线程的创建 介绍在Linux下线程的创建和基本的使用. Linux下的线程是一个非常复杂的问题,由 于我对线程的学习不时很好,我在这里只是简单的 ...

  7. Android Stuido中断点调试和高级调试

    写一个简单的调试程序 import android.os.Bundle; import android.support.v7.app.AppCompatActivity; public class M ...

  8. .NET高级调试系列-Windbg调试入门篇

    Windbg是.NET高级调试领域中不可或缺的一个工具和利器,也是日常我们分析解决问题的必备.准备近期写2篇精华文章,集中给大家分享一下如果通过Windbg进行.NET高级调试. 今天我们来一篇入门的 ...

  9. winform 跨线程操作控件

    当进行winform的开发时,经常遇到用时比较久的操作,在传统的单线程程序中,用户必须等待这个耗时操作完成以后才能进行下一步的操作,这个时候,多线程编程就派上用场了,将这个耗时的操作放到一个新的子线程 ...

  10. 扩展BindingList,防止增加、删除项时自动更新界面而不出现“跨线程操作界面控件 corss thread operation”异常

    在做界面程序时,常常需要一些数据类,界面元素通过绑定等方式显示出数据,然而由于UI线程不是线程安全的,一般都需要通过Invoke等方式来调用界面控件.但对于数据绑定bindingList而言,没法响应 ...

随机推荐

  1. 【DataBase】SQL优化问题

    在DAO层的动态SQL: //订单新增,查询配件主数据 @SuppressWarnings("rawtypes") public PageInfoDto getPartsForPa ...

  2. 【Project】原生JavaWeb工程 02 登陆业务的流程(第一阶段样例)

    1.对用户信息的描述 首先用户有一些基本信息: 最简单的: 用户名称 + 用户密码 然后是用户状态,例如封号,注销,停用,等等 用户名称 + 用户密码 + 账号状态 接着为了防止脚本攻击,又产生了图形 ...

  3. Ubuntu Firefox浏览器播放视频报错,提示“需要安装所需的视频编码器”——解决方法:安装视频解码器

    给电脑重新做了一个Ubuntu的系统,安装系统的时候没有选择安装第三方软件,结果开机进系统打开firefox浏览器看个电影报错,提示"需要安装所需的视频编码器",效果如下: 解决方 ...

  4. 《最新出炉》系列初窥篇-Python+Playwright自动化测试-64 - Canvas和SVG元素推拽

    1.简介 今天宏哥分享的在实际测试工作中很少遇到,比较生僻,如果突然遇到我们可能会脑大.懵逼,一时之间不知道怎么办?所以宏哥这里提供一种思路供大家学习和参考. 2.SVG简介 svg也是html5新增 ...

  5. FFmpeg开发笔记(四十五)使用SRT Streamer开启APP直播推流

    ​SRT Streamer是一个安卓手机端的开源SRT协议直播推流框架,可用于RTMP直播和SRT直播.SRT Streamer支持的视频编码包括H264.H265等等,支持的音频编码包括AAC.OP ...

  6. Android网页投屏控制从入门到放弃

    背景 业务需要采集在app上执行任务的整个过程,原始方案相对复杂,修改需要协调多方人员,因而考虑是否有更轻量级的方案. 原始需求: 记录完成任务的每一步操作(点击.滑动.输入等) 记录操作前后的截图和 ...

  7. SMU Summer 2023 Contest Round 2

    SMU Summer 2023 Contest Round 2 A. Treasure Hunt 当\(x1 - x2\)的差值与\(y1-y2\)的差值都能被\(x,y\)整除时,且商之和为2的倍数 ...

  8. 基于surging的产品项目-木舟开源了!

    一 . 概述 因为前段时间电脑坏了,导致代码遗失,踌躇满志马上上线的平台产品付之东流,现在熬夜在写代码希望能尽快推出企业正常使用的平台产品,而这次把代码开源,一是让大家对surging 使用有个深入的 ...

  9. homeassistant_Midea AC LAN使用问题记录

    1. hass life设备在通知中提示连接成功就不需要修改hass life 中的配置内容 2. 如果空调显示不可用, 只需要在 配置 - 集成 删除Midea AC LAN后重新自动添加即可

  10. 在 SQLAlchemy 中实现数据处理的时候,实现表自引用、多对多、联合查询,有序id等常见的一些经验总结

    有时候,我们在使用SQLAlchemy操作某些表的时候,需要使用外键关系来实现一对多或者多对多的关系引用,以及对多表的联合查询,有序列的uuid值或者自增id值,字符串的分拆等常见处理操作. 1.在 ...