【转】10个强大的Visuals Studio调试小技巧

article/2025/11/10 18:32:51

原文:http://www.codeproject.com/Articles/359801/10plus-powerful-debugging-tricks-with-Visual-Studi

简介
调试是软件开发周期中很重要的一部分。它具有挑战性,同时也很让人疑惑和烦恼。总的来说,对于稍大一点的程序,调试是不可避免的。最近几年,调试工具的发展让很多调试任务变的越来越简单和省时。

这篇文章总结了可能节省你大量时间的十个visual studio的调试技巧和方法。


1 悬停鼠标查看表达式值


调试是很有挑战性的。比如在函数内逐步运行可以看出哪里出错,查看堆栈信息可以知道函数被谁调用等等。。。
但是无论哪种情况下,查看表达式和局部变量的值都是很麻烦的(把表达式和局部变量放到watch窗口里)。
一种更简单的方法,把鼠标停在所需查看的数据上。如果是类或结构,那么点击展开可以很方便快速地查看其字段。


2 在运行过程中改变变量值


调试器不仅仅是分析程序崩溃和诡异行为的工具,还可以通过逐步调试检查数据和行为是否符合程序预期的方法解决许多bug。有时,你会想是否设置某些条件为真,程序就能正确运行了。其实你只要把鼠标移动到变量上,双击值,然后输入你需要的值。这样就不需要修改代码,重启程序了。


3 设置下一个运行位置


一个典型的调试案例是我们经常会用逐步调试的方法去分析为什么函数出错了。这时你遇到这个函数调用其他函数返回错误,而这个错误不是你想要的,你该怎么办?重启调试器?这里有个更好的方法,直接把黄色的运行位置箭头拖到你想要的运行位置。其实就是跳过中间运行代码,直接到想要的位置。很简单吧。


4 编辑然后继续运行


在运行一个很复杂的程序和插件时,发现一个错误,但是不想浪费时间去重编译重启动程序。
很简单,只要在这个位置修改这个bug,然后继续调试。Visual studio会修改这个程序,使得你可以继续调试而不需要重启程序。


值得注意的是“编辑然后继续运行”这个功能有几个限制。一,它不能在64位代码上使用。如果想使用这个功能,到项目设置里的编译选项,选择”x86”作为目标平台。不要担心,这目标平台在reslease配置是和”debug是分离的,也就是说依然是”Any  CPU”的设置。二,“编辑然后继续运行”这个功能仅适用于一个函数内部改变。如果你想要改变这个函数的声明或者增加新的方法,你只能选择重启程序,或者不做任何改变继续。如果修改的方法中包含lambda表达式,则意味着修改了编译器自动生成的委托类型,这样会导致编译器停止运行。


5 一个方便的查看窗口


大部分现代的调试器都有查看窗口。但是,visual studio的查看窗口使用特别简单,你能很方便的增加和删除变量。只要在窗口里点击空白行,输入表达式然后按enter键。或者点击表达式,按delete键删除不需要的表达式。


在调试窗口不仅仅可以查看普通的变量值,甚至可以输入$handles去追踪打开的句柄数量,$err去查看函数的错误代码(然后使用 Tools->Error 查看错误代码的描述)或者输入 @eax(在64位下是@rax )查看包含函数返回值的寄存器值。


6 注释反汇编


使用内部的反汇编功能使得优化局部代码更加简单。Visual studio可以在你的每一行代码下显示汇编指令,并且可以逐步调试汇编代码,也可以在任意位置设置断点。查看和修改汇编代码类似于c++。


7 堆栈信息的线程窗口


调试多线程代码是很痛苦的。或许也是有趣的。这取决于你的调试器。Visual studio 一个很赞的功能就是在线程窗口查看线程的堆栈信息。你能很方便的直接看到所有线程以及他们的堆栈信息。


8 条件断点


如果你想重现一个小概率事件,但是断点在大量不需要的条件下也会触发。你可以很简单的设置条件断点。在断点窗口设置该断点条件,Visual studio 会自动忽略不符合条件的断点。


9 内存窗口


一些bug是由错误的结构定义、缺少对齐属性等原因引起的。查看每行内存的内容很容易定位和解决这些bug. Visual studio 的内存窗口可以把数据翻译成8/16/32/64-bit数字或者浮点数。你可以在编辑窗口直接改变数值。


10 跳转到定义


如果你在解决别人写的代码一个bug,会遇到“这个类型是什么”“这个函数做什么的”之类的问题,你可以使用visual studio的跳转到定义的命令来查看类型或函数的定义。


11 命令窗口


这个小技巧是由chaau建议的,它能节省你大量的时间。Visual studio支持一个命令窗口,你可以通过菜单View->Other Windows->Command Window 打开。你可以在窗口里输入不同命令使调试自动化。比如,可以通过很简单的命令去的测试MFC的COleDateTime变量。

转载于:http://blog.csdn.net/zhleiyang/article/details/8605159

转载于:https://www.cnblogs.com/Snail-Blog/archive/2013/05/03/3056474.html


http://chatgpt.dhexx.cn/article/ujR4vhdE.shtml

相关文章

12个高效的VS调试技巧

介绍 调试是软件开发周期中的一个很重要的部分,有时很有挑战性,有时候则让程序员迷惑,有时候让程序员发疯,但是。可以肯定的是,对于任何不是太那个微不足道的程序来说,调试是不可避免的。近年来&#xff0c…

11个高效的VS调试技巧

介绍 调试是软件开发周期中的一个很重要的部分,有时很有挑战性,有时候则让程序员迷惑,有时候让程序员发疯,但是。可以肯定的是,对于任何不是太那个微不足道的程序来说,调试是不可避免的。近年来&#xff0c…

VC序列化问题(Serialize)

文档与序列化 一、文档的基本特征 文档类文件是从CDocument继承而来的。 The CDocument class provides the basic functionality for user-defined document classes. A document represents the unit of data that the user typically opens with the File Open comman…

MFC和ATL共享的选件类

从Visual C .NET 2002中启动,一些现有MFC实用工具选件类复盖或修改减少它们在其他MFC选件类的依赖项。这些实用工具选件类现在可用于任何本机C项目。本节包含仅是前面提供对MFC项目和现在共享的选件类,以及一些新选件类与 CString中的更改相关。不包括AT…

Visual studio调试技巧的总结与如何检测内存泄漏问题?

1、如何使用VS自带的功能函数来进行整个工程代码是否有内存泄漏问题: 参考博客:http://blog.sina.com.cn/s/blog_149e9d2ec0102wyvr.html (介绍_CrtSetDbgFlag函数) 参考博客:vs中内存泄漏检测的方法总结 &#xf…

克鲁斯卡尔算法生成最小生成树

克鲁斯卡尔算法的介绍 1)克鲁斯卡尔(Kruskal)算法,是用来求加权连通图的最小生成树的算法。 2)基本思想:按照权值从小到大的顺序选择 n-1条边,并保证这 n-1条边不构成回路 3)具体做法:首先构造一个只含 n个顶点的森林&#xff…

克鲁斯卡尔算法学习(Java)

克鲁斯卡尔算法学习(Java) 学习视频:尚硅谷韩老师java讲解数据结构和算法 一、应用场景-公交站问题 某城市新增 7 个站点(A, B, C, D, E, F, G) ,现在需要修路把 7 个站点连通各个站点的距离用边线表示(权) ,比如 A …

克鲁斯卡尔算法 与 普里姆算法

克鲁斯卡尔算法 设G(V,E)是具有n个顶点的连通网,T(U,TE)是其最小生成树。 1、选取权值最小的边(Vi,Vj),若边(Vi,Vj&…

最小生成树:克鲁斯卡尔算法+普里姆算法

目录 一、最小生成树 二、克鲁斯卡尔算法 1、思路 2、示例 3、C语言代码 三、普里姆算法 1、思路 2、C语言代码 一、最小生成树 一棵最小生成树需要满足哪些条件呢? 不存在回路对于具有n个顶点的连通网,其生成树中只能有n-1条边,这…

用c语言描述普里姆算法和克鲁斯卡尔算法,克鲁斯卡尔算法+普里姆算法 详解

克鲁斯卡尔算法: 【1】克鲁斯卡尔算法 普里姆算法是以某顶点为起点,逐步找各顶点上最小权值的边来构建最小生成树。 克鲁斯卡尔算法是直接以边为目标去构建。 因为权值是在边上,直接去找最小权值的边来构建生成树也是很自然的想法,只不过构建时要考虑是否会形成环路而已。 …

十大算法之克鲁斯卡尔算法

克鲁斯卡尔算法介绍 克鲁斯卡尔(Kruskal)算法,是用来求加权连通图的最小生成树的算法。 基本思想:按照权值从小到大的顺序选择n-1条边,并保证这n-1条边不构成回路 具体做法:首先构造一个只含n个顶点的森林,然后依权值…

0096 克鲁斯卡尔算法,迪杰斯特拉算法

/* * 克鲁斯卡尔算法 * 1.用来求加权连通图的最小生成树的算法 * 2.思想:按照权值从小到大的顺序,选择n-1条边,并保证这n-1条边不构成回路 * 3.先构造一个只含n个顶点的森林,依权值从小到大从连通网中选择边加入到森林中 * …

普里姆 克鲁斯卡尔算法

一.简介 连通图:任意2节点之间都有路径相通 最小生成树:最小权重生成树 一个 n 结点的连通图的生成树是原图的极小连通子图,且包含原图中的所有 n 个结点,并且有保持图连通的最少的边(n-1)。 最小生成树可…

c语言克鲁斯卡尔算法

克鲁斯卡尔思路以及代码分析 我们用邻接矩阵来表示该图,克鲁斯卡尔算法思想及找到最小边,查看是否形成回路,若形成回路则这条边不形成,若不形成回路则构成最小路径,以此类推。(思路和代码都在下方&#xff…

了解克鲁斯卡尔算法

文章目录 Kruskal算法如何工作Kruskal算法的示例Kruskal算法伪代码C示例Kruskal算法 vs Prim算法Kruskal算法的复杂度Kruskal算法的应用参考文档 在本教程中,您将学习Kruskal算法如何工作。此外,您还将找到C语言的示例。     Kruskal算法是一种最小生…

克鲁斯卡尔算法

什么是克鲁斯卡尔算法 在知道克鲁斯卡尔算法之前我们先来看一下什么是最小生成树。 最小生成树:在一个有n个结点的无向图中选出最少的边,保证所选边权相加之和最小以及该图中依然有n个结点并且n个结点连通。一共有n个结点,要保证连通&#…

Kruskal算法(克鲁斯卡尔算法)

Kruskal算法 Kruskal算法是一种用来查找最小生成树的算法,由Joseph Kruskal在1956年发表。用来解决同样问题的还有Prim算法和Boruvka算法等。三种算法都是贪心算法的应用。 概念解释 Kruskal算法定义:**先构造一个只含 n 个顶点、而边集为空的子图&…

KruskalAlgorithm(克鲁斯卡尔算法)

KruskalAlgorithm介绍 克鲁斯卡尔(Kruskal)算法,是用来求加权连通图的最小生成树的算法。基本思想:按照权值从小到大的顺序选择 n-1 条边,并保证这 n-1 条边不构成回路具体做法:首先构造一个只含 n 个顶点的森林,然后…

数据结构——克鲁斯卡尔(Kruskal)算法

克鲁斯卡尔算法是求连通网的最小生成树的另一种方法。与普里姆算法不同,它的时间复杂度为O(eloge)(e为边数),适合于求边稀疏的网的最小生成树 。克鲁斯卡尔算法从另一途径求网的最小生成树。其基本思想是&a…

克鲁斯卡尔(Kruskal)算法(严蔚敏C语言)

克鲁斯卡尔算法(Kruskal) ​ 克鲁斯卡尔算法是求连通网的最小生成树的另一种方法。与普里姆算法不同,它的时间复杂度为O(eloge)(e为网中的边数),所以,适合于求边稀疏的网的最小生成树 。 ——百…