1.什么是bug?
bug--->臭虫、虫子。
为什么含义是臭虫、虫子呢?
答案是:第一次被发现的导致计算机错误的是一只飞蛾,也是第一个计算机程序的错误。
2.调试是什么?有多重要?
前言:
所有发生的事情都一定有迹可循,如果问心无愧,就不需要掩盖也就没有迹象了,如果问心有愧,就必然需要掩盖,那就一定会有迹象,迹象越多就越容易顺藤而上,这就是推理的途径。
顺着这条途径顺流而下就是犯罪,逆流而上就是真相。
一名优秀的程序员都是一名出色的侦探。
每一次调试都是尝试破案的过程。
2.1调试是什么?
调试(英语:Debugging/Debug),又称除错,是发现和减少计算机或电子仪器设备中程序错误的一个过程。
2.2调试的基本步骤
①发现程序错误的存在
②以隔离、消除等方式对错误进行定位
③确定错误产生的原因
④提出纠正错误的解决办法
⑤对程序错误予以改正,重新测试
2.3Debeg和Release的介绍
Debug通常称为调试版本,它包含调试信息,并且不做任何优化,便于程序员调试程序。
Release称为发布版本,它往往是进行了各种优化,使得程序在代码大小和运行速度上都是最优的,以便用户很好地使用。
(1)在VS2019中如何转换?
(2)Release对代码大小上是最优的:
代码:
#include<stdio.h> //自定义函数——实现对整数数组的冒泡排序 void bubble_sort(int* str, int sz) { //趟数 int i = 0; for (i = 0; i < sz - 1; i++) { //一趟冒泡排序的过程 int j = 0; for (j = 0; j < sz - 1 - i; j++) { //升序 if (str[j] > str[j + 1]) { int tmp = str[j]; str[j] = str[j + 1]; str[j + 1] = tmp; } } } } int main() { int arr[] = { 10,9,8,7,5,6,4,1,2,3 };//定义整形数组,并初始化 int sz = sizeof(arr) / sizeof(arr[0]);//计算数组的大小 //调用函数,实现升序 bubble_sort(arr, sz); //输出升序后的数组 int i = 0;//循环变量 for (i = 0; i < sz; i++) { printf("%d ", arr[i]); } printf("\n"); return 0; }
观察分别在Debeg和Release环境下生成的可执行程序的大小:
(3)Release对代码运行速度上是最优的
代码:
#include <stdio.h> int main() { int i = 0; //数组下标界限0~9 int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; for (i = 0; i <= 12; i++) { //数组下标为10~12时数组越界 arr[i] = 0; printf("hehe\n"); } return 0; }
在Debeg和环境下该代码死循环,解释在调试的实例二。
在Release环境下该代码打印13次hehe,不死循环,因为编译器优化把i的地址放在数组arr地址的下面了。
3.Windows环境调试介绍
3.1调试环境的准备
在环境中选择debug选项,才能使代码正常调试。
3.2学会快捷键
最常使用的几个快捷键:
F5
启动调试,经常用来直接跳到下一个断点处。
F9
创建断点和取消断点。
断点的重要作用,可以在程序的任意位置设置断点。这样就可以使得程序在想要的位置停止执行,继而一步步执行下来。
F5和F9常配合使用,F5一般不会单独使用的。断点再多文件、多代码中常用。
F10
逐过程,通常用来处理一个过程,一个过程可以是一次函数调用,或者是一条语句。
F11
逐语句,就是每次都执行一条语句,但是这个快捷键可以使我们的执行逻辑进入函数内部(这是最常用的)。
ctrl + F5
开始执行不调试。如果你想让程序直接运行起来而不调试就可以直接使用。
3.3调试的时候查看程序当前信息
注意:只有先F10开始调试,才能看到程序当前信息。
3.3.1查看临时变量的值
在调试开始之后,用于观察变量的值。
3.3.2查看内存信息
在F10调试开始之后,用于观察内存信息。
3.3.3查看汇编信息
在F10调试开始之后,有两种方式转到汇编。
(1)第一种方式:右击鼠标,选择[转到汇编]:
(2)第二种方式:
可以切换到汇编。
3.3.4查看寄存器信息
在F10调试起来之后,有两种方式观察寄存器信息。
(1)第一种方式:
(2)知道寄存器的名字,可以在监视中观察寄存器信息。
可以查看当前运行环境的寄存器的使用信息。
3.3.5查看调用堆栈
在F10调试之后,可以观察调用堆栈。
通过调用堆栈,可以清晰的反应函数的调用关系以及当前调用所处的位置。