.Net多线程编程—使用Visual Studio 2012进行调试

1 相关概念

1)栈帧

C语言中,每个栈帧对应着一个未运行完的函数。栈帧中保存了该函数的返回地址和局部变量。

栈帧也叫过程活动记录,是编译器用来实现过程/函数调用的一种数据结构。

2)单步执行与单步函数执行

单步执行又被称为逐语句执行,单步函数执行又被称为逐过程执行。单步函数执行不会进入函数体。

3)主线程不会显示在Parallel Tasks 窗口中,因为主线程不是任务。但它会显示在显示线程的窗口中。

2 Parallel Tasks 窗口

打开窗口:

断点调试情况下,按F5或点击“启动调试”,如下图所示

在上步基础上,点击“调试”——>“窗口”:

在上步基础上,点击“任务”:

在上步基础上,右键单击任务窗口,调出菜单,可以调出为每一个任务分配的线程:

说明:

1)下图显示没有任务可显示,这是因为,将断点打到图示位置,还没有执行任务。

2)在Parallel Tasks 窗口中,双击一个任务,可显示所选任务将要运行的下一条语句。

3)任务还没有分配时,Parallel Tasks 窗口中没有任何信息显示,下图状态中按F10逐过程执行,会出现一条信息,如下图所示:

接着,继续按F10,会出现第二条信息,如下图所示:

上面两幅图中Parallel Tasks 窗口左侧的黄色箭头指示当前任务。

4)只关注一个任务

为了能够在有多个任务并行执行的时候,专注观察一个任务的执行情况,可使用“冻结线程”功能。

如下图所示,Parallel Tasks 窗口中有5个任务,其中1个已分配,4个在执行。

在上图中,右键,调出菜单,选择

,结果一次入下面两幅图:

上图中蓝色的暂停标识表示被冻结的任务。

值得注意的是:我们的程序中有五个任务,然而这里显示四个任务在运行,还有一个已分配,那么它是没有被冻结的,所以还不能够实现专注调试一个任务的目的,待到这个任务运行时,将其冻结后,才可专注调试一个任务。

下图是只有一个活动的任务。

再者:F10为逐过程运行,F11为逐句运行,调试时请使用F11,逐句调试更易发现问题。

5)切换到任务

在Parallel Tasks 窗口,右键点击调出菜单,选择“切换到任务”,可以定位到那个任务对应的匿名方法

3 Threads窗口

断点调试状态下,按F5或点击“启动调试”,然后点击“调试”——>“窗口”——>“线程”:

说明:

1)双击Threads窗口中相应的行可以看到将要执行下一行语句或线程的当前行,如下图所示:

2)Threads窗口不一定会将所有任务都显示出来。

如下图,所示将断点打在第13行,只能看到主线程被加载,其他的任务都没有显示出来。

多加几个断点,如下图所示:

按F5,如下图所示:

双击上图中某一条,注意窗口信息的变化。

 4 Call Stack窗口

断点调试状态下,按F5或点击“启动调试”,然后点击“调试”——>“窗口”——>“调用堆栈”

在上图Call Stack窗口中,右键单击,调出菜单。

5 Parallel Stack窗口

断点调试状态下,按F5或点击“启动调试”,然后点击“调试”——>“窗口”——>“并行堆栈”

Parallel Stack窗口的左上角

可以切换显示线程和任务,切换到任务,显示如下:

说明:

1)节点之间的箭头表示任务或线程整体的调用路径,蓝色高亮箭头表示当前任务或线程的路径。

2)同时调出Parallel Stack和Parallel Task窗口,Parallel Stack设置如下图:

双击Parallel Task中的一条任务,可匹配到Parallel Stack中的任务。

将Parallel Stack切换到线程视图,蓝色的为对应部分。

点击红框中的图表,可得下面的视图

6 实战运用

检测死锁

具体程序代码见易错点分析那部分。

按F5,然后“调试”——>“全部中断”,可得下面的结果,从图中可以看出两个任务状态都为“死锁”,双击每一条,可定位到相应的任务。

  -----------------------------------------------------------------------------------------

时间仓促,水平有限,如有不当之处,欢迎指正。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏有刻

Linux 小记 — Ubuntu 自动化配置

390100
来自专栏pangguoming

C# WCF 完整实例,winform 窗体作为 宿主

上一次提到,我们的WCF程序宿主是发布到IIS上面的。虽然这样做未尝不可,不过不便于我们进行“开始”或“停止”WCF服务的操作。所以再次尝试了编写以窗体应用程序...

57940
来自专栏张戈的专栏

解决WordPress升级4.2后调用国外图片导致大量404请求的问题

前几天就收到 WordPress 官方发来的预更新通知,告诉我本周会更新到 4.2。果然,昨天就收到了更新推送消息,随手就点击升级了,前台打开看了下没有看到明显...

375100
来自专栏Jerry的SAP技术分享

S/4HANA for Customer Management里的搜索分页处理

这篇文章的英文版我发在了SAP Community上:Paging Implementation in S/4HANA for Customer Managem...

40140
来自专栏大数据钻研

谈谈JS中的函数节流

好吧,一直在秋招中,都没怎么写博客了。。。今天赶紧来补一补才行。。。我发现,在面试中,讲到函数节流好像可以加分,尽管这并不是特别高深的技术,下面就聊聊吧! ^_...

36480
来自专栏逻辑熊猫带你玩Python

Python | Time Marker时间标签(附详细注释)

如果您之前关注过我的内容,可以回忆一下我之前发过两篇关于文章,如果没有可以进入下面链接:

12610
来自专栏ASP.NET MVC5 后台权限管理系统

构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(14)-EasyUI缺陷修复与扩展

不知不觉已经过了13讲,(本来还要讲多一讲是,数据验证之自定义验证,基于园友还是对权限这块比较敢兴趣,讲不讲验证还是看大家的反映),我们应该对系统有一个小结。 ...

21160
来自专栏葡萄城控件技术团队

深入解析 DataGrid 过滤功能

过滤是DataGrid这样的表格控件的基本功能之一,也是非常重要的特性。微软提供的标准DataGrid相信大家都很熟悉了。本文要解析的不是标准DataGrid,...

26370
来自专栏指尖下的Android

AndroidStudio AAPT2 error: check logs for details报错解决方案

1.1K20
来自专栏小程序容器

OpenApplus小程序容器

OpenApp+ (https://www.openapplus.com)一个小程序容器,配置简单、功能完善、界面流畅、开箱即用!使用OpenApp+可以快速扩...

62890

扫码关注云+社区

领取腾讯云代金券