实用调试技巧
前言
本文主要是学习常用得调试方法,自己也是初学C,介绍的简单,也请大家多多指教,主要内容包括:
- 什么是bug?
- 调试是什么?有多重要?
- debug和release的介绍
- windows环境调试介绍
- 一些调试的实例
- 如何写出好(易于调试)的代码
- 编程常见的错误
1、bug是什么?
百度百科关于bug的介绍:
2、调试是什么?有多重要?
2.1 调试是什么?
调试(英语:Debugging / Debug),又称除错,是发现和减少计算机程序或电子仪器设备中程序
错误的一个过程。
2.2 调试的基本步骤
- 发现程序错误的存在
- 以隔离、消除等方式对错误进行定位
- 确定错误产生的原因
- 提出纠正错误的解决办法
- 对程序错误予以改正,重新测试
2.3 Debug和Release的介绍
- Debug 通常称为调试版本,它包含调试信息,并且不作任何优化,便于程序员调试程序
- Release 称为发布版本,它往往是进行了各种优化,使得程序在代码大小和运行速度上都是最优
的,以便用户很好地使用
int main()
{
int i = 0;
int arr[10] = {0};
for(i=0; i<=12; i++)
{
arr[i] = 0;
printf("hehe\n");
}
return 0;
}
- 如果是 debug 模式去编译,程序的结果是死循环
- 如果是 release 模式去编译,程序没有死循环
二者之间的差异就是因为优化导致的。
3、Windows环境调试介绍
3.1 调试环境的准备
在环境中选择 debug 选项,才能使代码正常调试
3.2 快捷键的使用
下面是调试常用的快捷键:
- F5: 启动调试,经常用来直接跳到下一个断点处
- F9:创建断点和取消断点。断点的重要作用,可以在程序的任意位置设置断点。这样就可以使得程序在想要的位置随意停止执行,继而一步步执行下去
- F10:逐过程,通常用来处理一个过程,一个过程可以是一次函数调用,或者是一条语句
- F11:逐语句,就是每次都执行一条语句,但是这个快捷键可以使执行逻辑进入函数内部,这是最常用的
- CTRL + F5:开始执行不调试,如果你想让程序直接运行起来而不调试就可以直接使用
3.3 调试中查看程序当前信息
3.3.1 查看临时变量的值
在调试开始之后,用于观察变量的值
3.3.2 查看内存信息
在调试开始之后,用于观察内存信息
3.3.3 查看调用堆栈
通过调用堆栈,可以清晰的反应函数的调用关系以及当前调用所处的位置
3.3.4 查看汇编信息
3.3.5 查看寄存器信息
4、调试要点
- 一定要熟练掌握调试技巧
- 初学者可能80%的时间在写代码,20%的时间在调试。但是一个程序员可能20%的时间在写程序,但是80%的时间在调试
- 我们所讲的都是一些简单的调试。
以后可能会出现很复杂调试场景:多线程程序的调试等。 - 多多使用快捷键,提升效率
5、举例说明
下面举例说明在程序中应用调试找出代码中隐藏的bug,调试环境仅限于Win 10 + VS 2017
int main()
{
int i = 0;
int arr[10] = {0};
for(i=0; i<=12; i++)
{
arr[i] = 0;
printf("hehe\n");
}
return 0;
}
乍得一看,程序越界了,运行出错,但ctrl+ f5实际运行后,发现程序陷入了死循环。通过F10 +F11来调试:
1、查看内存的数值,a[0]-a[9]这里是正常没问题的
2、查看内存的数值,a[10]-a[12]这里,虽然超出数组范围,但是程序仍然正常运行,打印 hehe
3、查看内存的数值,当i=13时,a[13]这里发现问题了,此时 a[13] 的地址与 i 的地址重合了。
4、a[13]=0,改变了地址里的值,因为两个地址是同一个内存空间,意味 i 的取值也改为0 了。
5、简要来说:
- 当i=13时,a[13]和I的地址重合了,两个地址是同一个内存空间,数值是一样的
- a[13]=0,改变了地址里的值,意味 i 的取值也改为0 了,
- 此时i=13,变成了 i=0,这样程序就陷入死循环了
6、如何写出好的代码
- 代码运行正常、bug很少、效率高、可读性高、可维护性高、注释清晰、文档齐全
- 使用assert、尽量使用const、养成良好的编码风格、添加必要的注释、避免编码的陷阱
7、编程常见的错误
- 编译型错误:直接看错误提示信息(双击),解决问题。或者凭借经验就可以搞定。相对来说简单
- 链接型错误:看错误提示信息,主要在代码中找到错误信息中的标识符,然后定位问题所在。一般是标识符名不存在或者拼写错误
- 运行时错误:借助调试,逐步定位问题
总结
自己在学习过程中用F10、F11比较多,因为想监视变量的变化情况,变量在内存中存储的变化情况。
写好程序打印结果时,直接用Ctrol + F5。
写比较长的代码时,每当完成一个小功能时,就需要调试了,而不应该整个都写完了再去调试。这样程序有问题,排查难度大大提升了。
学好语言很重要,学好调试就是锦上添花。初学C语言,调试总结写的的很简单,感谢大家友好指正。