使用跟踪语句
31.OutputDebugString API函数,MFC AfxOutputDebugString 宏和MFC AfxDumpStack 函数在所有版本中均被编译,但是其他所有的跟踪语句仅在定义了_DEBUG符号时,才能被编译。
32.跟踪语句不能包含程序代码或对程序代码有间接的影响作用。跟踪语句的目的是向程序员提供信息,而不是用户。
33.与断言的区别:
(1)跟踪语句是无条件的。断言是有条件的布尔语句,而跟踪语句却总可以执行。
(2)跟踪语句不直接显示bug。断言用于显示出bug,而跟踪语句用于显示程序执行和变量值。
(3)跟踪语句可以被随便的忽略。默认情况下,断言打断程序的执行,并弹出一个消息框等待用户或程序员的响应;跟踪语句则将信息输出到调试窗口或文件中,于是很容易被程序员忽略。这种特点使得跟踪语句对于整体上程序的检验和程序的警告是非常理想的。一个很好的类比是:断言对编译器错误,跟踪语句对编译器警告。
34.void OutputDebugString(LPCTSTR traceText),这个windows API函数是Windows的一部分,因此它一直是有效的,这使得这个函数适用于在程序启动和结束过程中的跟踪。与此相反,Visual C++的C运行时刻函数库和MFC跟踪语句并不适用跟踪程序启动和结束,因为它们仅在加载了它的DLL之后才有效。如果你只想在调试版本中使用OutputDebugString,可以使用下面的宏来实现:
#ifdef _DEBUG
#define OutputTranceString(text) OutputDebugString(text)
#else
#define OutputTranceString(text) ((void) (0))
35.ANSI C++运行时刻函数库中并没有跟踪语句,但是它有用于跟踪的标准字符模式的输出流,具体有:C语音的stderr流和C++语言的cerr 和 clog流。stderr不需要缓冲区,cerr使用单位缓冲,clog使用完全缓冲。
36.使用MFC Tracer工具来控制MFC本身输出的跟踪语句
37.跟踪语句的有效使用需要一个策略,太多的跟踪消息会降低它们的有效性。如下是两个基本的跟踪语句策略:
(1) 调试器补充策略:使用跟踪语句补充由交互式调试器提供的信息
(2) 调试器代替策略:使用跟踪语句代替交互式调试器
38.使用综合诊断跟踪语句能让你查看程序中最引入注意的事件;使用特殊诊断跟踪语句来解决一个特殊的问题;一旦确定的问题已经解决,将用于特殊诊断的跟踪语句删除。
39.在交互式调试器不能解决问题的情况下,如:调试服务器、跨机器调试(如DCOM)、夸程序设计语言调试遇到编程语句、跨进程调试遇到进程、调试线程、远程调试、遇到那些因为海森堡不确定原理而很难调试的程序动作。使用跟踪语句解决问题。
40.跟踪调试技巧
(1)使用DebugView实用程序
(2)考虑提供一个重定向输出设置
(3)处理长字符串
(4)处理大量的跟踪输出
(5)产生调试报告
(6)输出独立行,而且不要忘了新行(newline)字符
(7)别忘了检查跟踪语句
注意:每当你的程序中有错误而你想得到更多信息的时候,你应该去查看一下跟踪消息