DebugView 使用技巧

 

From:https://blog.csdn.net/bcbobo21cn/article/details/52401087

 

 

DbgView简介

 

1、什么是 DebugView ?

DebugView是一个系统调试信息输出的捕获工具。debugview 是 Sysinternals 公司的系列调试工具。debugview 可以捕获程序中由 TRACE(debug版本)和 OutputDebugString 输出的信息。debugview 也是一个 Debug 信息捕获软件,可以很方便的捕获系统实时输出的Debug信息,并保存为日志文件。可以远程捕获服务器上的Debug信息。  比较方便开发人员在系统发布前监控一些系统流程和异常,甚至在系统不大的情况下,更能在部署后进行远程监控功能。 

 

2、DebugView它能干吗 ?

可以捕获程序中由 TRACE()和 OutputDebugString() 输出的信息。说的具体一点,在程序中使用如下函数:

  • 1)OutputDebugString  或者在MFC中使用TRACE
  • 2)内核模式中使用 Out_Debug_String,DbgPrint ,_Debug_Printf_Service 

编译程序为 DEBUG版本,然后运行程序(注意:不是在vs中运行,是单独运行),打开DebugView 就可以在其中看到输出的调试信息。

 

3、DebugView初体验:

  • 1)、打开DebugView,然后在菜单栏中选择Computer-->Connect Local,连接本地调试。
  • 2)、了解工具栏几个常用的按钮功能:

过滤器的功能比较实用:include 表示调试信息包含的字符串,exclue 表示不包含的字符串,多个字符串使用“;”号隔开。

  • 3)、测试程序:
#include <tchar.h>
#include <stdlib.h>
#include "windows.h"#define UseDebugViewint main()
{int nRepeatTimes = 0;
#ifdef UseDebugViewdo {TCHAR _buf[256] = { 0 };swprintf_s(_buf, 256, L"KANDY--正在进行第<%d>次连接...\n", nRepeatTimes);OutputDebugStringW(_buf);nRepeatTimes++;Sleep(1000);} while (nRepeatTimes < 3);
#endifsystem("pause");return 0;
} 

 

4、DebugView输出的信息:

 

 

实际操作

 

一张图教你如何使用 debugview

  • 1. 捕捉 Release模式的 Win32程序输出的调试信息,请选中 “Capture Global Win32”选项
  • 2. 只有调用了WinDebug中的方法输出的Debug打印信息才能被Debugview捕获

Debugview 也支持远程调试,在本机运行Dbgview.exe /c/s/t 可以让DebugView以服务的形式运行。
在远端打开Debugview,点击Computer/connect ,输入查看调试信息主机的IP ,点击确定即可。

使用DebugView时候可以选择捕获程序调试信息为用户程序或者内核程序。 

注意: Debugview 的过滤功能,比较实用,include 表示调试信息包含的字符串,exclue 表示不包含的字符串,多个字符串使用“;”号隔开。

 

Computer 菜单下可选择连接的计算机,默认连接本机:

输入IP或名字可连远程计算机:

下面四个按钮,第一个放大镜的,控制捕获的打开或关闭;第二个控制是否捕获系统内核的Debug信息;第三个控制是否捕获Win32应用的Debug信息:

这是本机捕获的情况;

点击漏斗型按钮,打开过滤器设置,在Include中输入TRACE,在Exclude中输入WAIT_TIMEOUT;这样就只显示带字符串“TRACE”的debug信息,不显示带“WAIT_TIMEOUT”的调试信息;

过滤以后的结果;

漏斗型按钮旁边的按钮控制显示记录的条数;下图显示16条;

捕获菜单中,默认捕获的是Win32,Pass-Through,Events;全局Win32,内核等,默认没有捕获;

选项菜单,可以选择是否显示Win32进程ID,是否滚动显示等;

 

 

TRACE宏 和 Dbgview

 

http://blog.163.com/gou_ya/blog/static/102080580200810274839532/

debugview  

1、用debugview,打开debugview,运行你的debug版本程序,可以定位到源文件的某一行。 

2、包含stdlib.h crtdbg.h 两个头文件 
在程序开始处添加 #define _CRTDBG_MAP_ALLOC 
在程序结束处添加 _CrtDumpMemoryLeaks(); 
比如 :

#define _CRTDBG_MAP_ALLOC int main(void) 
{ char *p = new char; return 0; _CrtDumpMemoryLeaks(); 
} 

运行debug版本的程序。在输出信息栏里会有内存泄露信息,可以定位到某一行 
以上两种方法不是没种泄露都能定位,如果不能,会输出内存泄露信息和发生泄漏的模块,那就要自己想想,什么地方出现了泄露

TRACE宏对于VC下程序调试来说是很有用的东西,有着类似printf的功能;该宏仅仅在程序的DEBUG版本中出现,当RELEASE的时候该宏就完全消失了,从而帮助你调试也在RELEASE的时候减少代码量。 

使用非常简单,格式如下: 

TRACE("DDDDDDDDDDD"); 
TRACE("wewe%d",333); 

同样还存在TRACE0,TRACE1,TRACE2。。。分别对应0,1,2。。个参数 
TRACE信息输出到VC IDE环境的输出窗口(该窗口是你编译项目出错提示的那个窗口),但仅限于你在VC中运行你的DEBUG版本的程序。 
TRACE信息还可以使用DEBUGVIEW来捕获到。这种情况下,你不能在VC的IDE环境中运行你的程序,而将BUILD好的DEBUG版本的程序单独运行,这个时候可以在DEBUGVIEW的窗口看到DEBUGVIE格式的输出了。 

VC中TRACE的用法有以下四种: 

  • 1: TRACE ,就是不带动态参数输出字符串, 类似C的printf("输出字符串"); 
  • 2: TRACE 中的字符串可以带一个参数输出 , 类似C的printf("...%d",变量); 
  • 3: TRACE 可以带两个参数输出,类似C的printf("...%d...%f",变量1,变量2); 
  • 4: TRACE 可以带三个参数输出,类似C的printf("...%d,%d,%d",变量1,变量2,变量3); 

TRACE 宏有点象我们以前在C语言中用的Printf函数,使程序在运行过程中输出一些调试信息,使我们能了解程序的一些状态。但有一点不同的是: 
TRACE 宏只有在调试状态下才有所输出,而以前用的Printf 函数在任何情况下都有输出。和Printf 函数一样,TRACE函数可以接受多个参数如: 

int x = 1; 
int y = 16; 
float z = 32.0; 
TRACE( "This is a TRACE statement\n" ); 
TRACE( "The value of x is %d\n", x ); 
TRACE( "x = %d and y = %d\n", x, y ); 
TRACE( "x = %d and y = %x and z = %f\n", x, y, z ); 

要注意的是TRACE宏只对Debug 版本的工程产生作用,在Release 版本的工程中,TRACE宏将被忽略。 

 

 

C#中使用

 

在C#中的使用方法:  将WinDebug.cs加入到项目中,也可以编译成.dll文件引入。然后在程序中需要输出调试信息调用即可。 

另外,如果要在运行时应用不输出debug信息,可以将web.config或app.config中的 <system.web>   <compilation debug="true" targetFramework="4.0"/> 设置为false,然后在调用WinDebug的地方就不会再输出Debug信息了
 

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/495536.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

儿子转眼就长大:Hinton、LeCun、Bengio 口述神经网络简史

1960 年的水牛城&#xff0c;工作人员正在「精细调节」一台感知机作者&#xff1a; 杨晓凡 刘鹏 思颖摘要&#xff1a;几位最偏执的人坚持到了春天来临谷歌母公司 Alphabet&#xff0c;亚马逊&#xff0c;苹果&#xff0c;Facebook 和微软这些全球最大的科技巨头们&#xff0c;…

VHDL 语法小点(1)

1.对于以时钟触发的计数器&#xff0c;一般从0到N-1&#xff0c;共N。当时钟上升沿来临时&#xff0c;对于可能用于判决的计数器的值&#xff0c;为上一次时钟周期内所修改的值&#xff0c;是上个时钟周期的值&#xff0c;很重要。 2.如何消除毛刺&#xff1a;可以通过用寄存器…

VS2019 更新MSDN并创建快捷方式

From&#xff1a;https://www.cnblogs.com/Lzl678/p/10686324.html VS2017 下载离线MSDN文档&#xff1a;https://blog.csdn.net/sinat_26222723/article/details/79109653 1. 在线 MSDN 使用方法 1. 进入微软中文官网&#xff1a;https://www.microsoft.com/zh-cn/ 2. 所有…

贝叶斯网络之父Judea Pearl:要建立真正的人工智能,少不了因果推理

来源&#xff1a;专知参与 | Yingying, Xiaowen, Sanglei 2011年图灵奖得主&#xff0c;贝叶斯网络之父Judea Pearl认为现在人工智能的发展进入的新的瓶颈期&#xff0c;各种新的成果不过本质上不过是重复简单的“曲线拟合”工作。Pearl 认为人们应该更关注人工智能中的因果&am…

结构思考力~结构思考力的四个基本特点

反例 “懂事长您好&#xff01;刘经理来电话说系统出现突发状况&#xff0c;4点钟他无法参加会议了。小张说他晚一点开会没关系&#xff0c;明天再开也可以&#xff0c;但最好别11点30分之前开。可是会议室明天已经被别人预订了&#xff0c;但是星期五空着的。王总的秘书说&am…

【转】 VC MFC 钩子 实现 自绘 窗体 标题栏 非客户区

效果&#xff1a; 程序&#xff1a; #if !defined(_LJF_LJFHOOK_H)#define _LJF_LJFHOOK_H #if _MSC_VER > 1000#pragma once#endif #include <afxtempl.h>#define sLjfDialogOldProcTag _T("CDialog_oldProc")#define SYSBTN_NON -1#define SYSBTN_MIN 0#d…

Jupyter 安装使用

Jupyter的官网&#xff1a;http://jupyter.org/index.html 官方文档&#xff1a;https://jupyter-notebook.readthedocs.io/en/stable/https://github.com/jupyter/jupyter/wiki/A-gallery-of-interesting-Jupyter-Notebooks 1. jupyter notebook是什么 官网的介绍是&#xff…

机器人创世2500年简史:从公元前的木鸽到21世纪的波士顿机器狗

来源&#xff1a;InterestingEngineering编译&#xff1a;科技行者几个世纪以来&#xff0c;人类一直对机器人这一概念痴迷不已——从古代的石傀儡故事到现代科幻小说&#xff0c;我们时刻想象着以机械方式重现自身。尽管“机器人&#xff08;robot&#xff09;”一词由卡雷尔-…

结构思考力~结构化接收信息的三个步骤

第一步&#xff1a;识别信息中的事实、理由及结论。找出信息中哪些是观点类的&#xff0c;哪些是事实描述 类的信息&#xff0c;观点类的信息中哪些是结论、哪些是支撑结论的理由&#xff0c;并将它们区分开。 第二步&#xff1a;找到事实与观点的对应关系&#xff0c;并画出结…

VisualStudio 的 Spy++ —— 窗口、消息 的 查看分析利器

spy 中文使用手册&#xff1a;https://pan.baidu.com/s/1NtLQMP1odHDAla4VH8m9Mg 提取码&#xff1a;294c Spy使用方法&#xff1a;https://www.cnblogs.com/happykoukou/p/6755444.html 教你使用Spy查看软件的流氓行径&#xff1a;https://blog.csdn.net/zahuopuboss/ar…

plsql developer 创建表空间和临时表

PLSQL Developer 给oracle 10g 创建表空间 通过pl/sql登录到Oracle数据库上&#xff0c;然后执行菜单:文件/新建/命令窗口 &#xff0c;打开一个命令窗口然后在该命令窗口中执行脚本创建和删除表空间 创建表空间 Sql>create tablespace histdb datafile F:\oracle\product…

【南科大发言】人类赋予人工智能伦理,生物进化方向的突破是关键

作者&#xff1a;刘锋 互联网进化论 计算机博士这篇文章是根据2018年5月20日&#xff0c;我在南方科技大学举办的“人工智能时代的技术与人文&#xff1a;跨学科对话”学术研讨会上的发言内容整理形成、主要观点如下&#xff1a;生物进化方向不明朗&#xff0c;是导致人类社会…

《MFC初探》之变量类型

From&#xff1a;https://blog.csdn.net/a1459268562/article/details/70653695 MFC常用数据类型&#xff1a;https://www.cnblogs.com/xzxl/p/7955477.html 刚接触 MFC 的人一看到里面各种各样的关键字肯定傻眼了&#xff0c;仿佛完全是另外一门语言了&#xff0c;因为 MFC 中…

结构思考力~确定目标

ABCD目标法 受众&#xff08;Actor&#xff09; XXX条件&#xff08;Condition&#xff09;在XXX条件下行为&#xff08;Behavior&#xff09;完成XXX的任务/表现XXX的行为程度&#xff08;Degree&#xff09;达到XXX的标准或水平 例子&#xff1a;作为资深的销售经理&#xff…

WPF获取窗口句柄

.NET WinForm获取窗口句柄很方便&#xff0c;this.Handle搞定。 WPF就有些麻烦了&#xff0c;获取方法如下&#xff1a; 引入命名空间&#xff1a;using System.Windows.Interop; 获取方法&#xff1a;new WindowInteropHelper(this).Handle this是个Window类的实例 作者: 翟士…

谷歌如何利用人工智能重塑美国医疗行业?

来源&#xff1a;网络大数据谷歌正在押注未来医疗会变得数据结构化和人工智能化&#xff0c;它已经把 AI 运用到了疾病监测&#xff0c;新型数据基础设施和有潜力的保险等领域。在这篇报告里&#xff0c;我们将探索谷歌医疗行业的众多布局和未来可能会进入的领域。谷歌一直以来…

VS 编写 x64 内联汇编

From&#xff1a;https://www.cnblogs.com/talenth/p/9135626.html VS 中使用 X64 汇编&#xff1a;https://blog.csdn.net/kingswb/article/details/64108715 编写涉及系统特性的一些底层程序&#xff0c;特别是ShellCode&#xff0c;不可避免地要采用直接编写汇编代码的方式…

结构思考力~设定主题

一、确定结论&#xff1a;一个为目标服务的结论 二、包装主题&#xff1a;一个打动人心的主题 SPA主题确认法 确定主题&#xff0c;让表达观点明确&#xff0c;如果我们自己要写报告&#xff0c;就需要思考两个问题&#xff1a; 你要说服对方接受你什么观点&#xff1b;如何…

MSSQL中实现多表更新

续2010年11月09日的《SQL语句中CASE WHEN以及CAST的运用》一文&#xff0c;如果在基础数据教师表中添加了新的教师用户&#xff0c;而恰好添加的教师已经存在于教学成果数据中&#xff0c;则需要更新教学成果数据中该教师的信息&#xff0c;即&#xff1a;之前存储的是教师的姓…

VS2019 使用 C/C++ 动态链接库 并 进行调用

vs2019生成dll并调用的实现示例&#xff1a;https://www.jb51.net/article/179759.htm vs2017创建linux c程序&#xff1a;https://blog.csdn.net/qingyulove/article/details/86659726 vs2019编写Linux c/c项目&#xff1a;https://blog.csdn.net/mmmsss987/article/details/…