学会调试,让你也成为改bug能手

Posted KookNut39

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了学会调试,让你也成为改bug能手相关的知识,希望对你有一定的参考价值。

前言:最近有些粉丝问我一些代码问题,他们的代码大多不是复杂的项目,但是对于初学者,他们发现代码的执行结果不符合自己的预期,但是又不知道自己哪里出了问题。我相信这是对于很多初学者来说,都会遇到的问题和情况,明明代码是按照自己的理解写的,感觉逻辑也说得通,那到底哪里出了问题呢??
他们的bug其实不难解决,一般通过调试就可以找出问题所在,但是难搞的地方,就是他们不会调试。今天我们就来教大家调试代码,清晰的看看代码的执行流程,帮你顺利找到bug,提高自己的编码水平!

如果学会了,喜欢博主的文章,可以一键三连支持博主,我们以后的日子里慢慢处!!

声明:此文针对C/C++初学者,使用VS2017编译器进行范例讲解。

在这里插入图片描述

一、错误代码示范

首先来看一下我们的代码,我们预期它要输出"Parameter is not 7",结果它输出了"Parameter is 7",我想破了头也想不通哪里出问题了,内心独白就是“这么几句代码,我怎么可能写错?

void Function_1(int Parameter)
{
	int a = 1;
	int b = 2;
	if (Parameter = 7)
	{
		cout << "Parameter is 7" << endl;
	}
	else
	{
		cout << "Parameter is not 7" << endl;
	}
	return;
}

int main()
{
	int a = 5;
	Function_1(5);
	return 0;
}

二、开始调试

我们首先在VS2017中打开我们的C/C++项目,打开我们要调试的项目,接下来进入调试状态:

1. 下断点

首先来说一下下断点的意义,下断点,在我理解看来就是让程序执行流断开,在断点处停住,当我们开始调试的时候,程序会停留在断点处,此时我们可以查看变量内容,看程序目前的执行结果等等。那么如何下断点?我通常使用有2个方法:
(1)将鼠标移至想要下断的代码所在行的最左端,然后点击鼠标左键。
假如我们想要在65行处下断电,那么如下图所示:
在这里插入图片描述
点击完毕,左侧出现实心红点,效果如图:
在这里插入图片描述
(2)在我们想下断的行,点击鼠标左键,让鼠标处在那一行的任意位置,然后按键盘最上方的快捷键F9,就会有断点出现:
在这里插入图片描述
按F9之后,断点出现:
在这里插入图片描述
那我们想要取消这个断点该如何操作呢??同样的动作再来一次,它就取消了,可以直接将鼠标定位在指定行,然后按F9,或者直接点击最左侧的红色实心点,断点就取消了。

注意:断点可以下很多个,不止一个嗷~,我们这篇文章为了演示,我下两个断点,分别在main函数的第一句和Function_1()函数的 if 语句起始位置:
在这里插入图片描述

2. 开始调试

当我们下好断点之后,点击vs最上方工具栏调试–>开始调试,然后就可以进入调试状态,或者在断点下好之后,直接点击键盘最上方F5,也可以进入调试状态:
在这里插入图片描述
进入调试状态之后,会有一个黄色光标出现,这意味着调试的开始,黄色光标所指向的行,就是还未执行,但是接下来就要执行的行。

2.1 单步步过

执行调试可以单步步过,也可以直接执行到下一个断点,跳过中间的步骤,如果我们一开始不知道问题出在哪里,可以选择在最初的一句下断点,然后点击VS最上方工具栏调试–>逐过程,就可以执行到当前断点的下一条语句,或者直接按快捷键F10,也可执行同样效果
在这里插入图片描述
执行一步之后,效果如图:
在这里插入图片描述
此时我们来到了一个函数处,如果我们想要单步步过,那就不在Function_1()函数中下断点,然后点击F10,断点将到达return 0;处。如果我们想要进入函数,可以怎么办?

2.2 单步步入

当我们光标执行到Function_1()处,想看看里面发生的情况,那么可以点击工具栏调试–>逐语句,或者直接键盘上方快捷键F11,就会进入函数内部:
在这里插入图片描述
进入之后,如下图所示:
在这里插入图片描述
此时我们可以用F10单步步过来继续执行调试。但是当我们觉得前面这些步骤都没必要,我感觉问题就出在 if 语句这里,于是在这里下了断点,我能不能直接加将光标执行到这里呢?

2.3执行到断点处

想要直接执行到断点处,我们可以怎么操作?加入我们一开始处于这里:
在这里插入图片描述
接下来点击工具栏调试–>继续,或者直接键盘上方快捷键F5,就可以到达下一个断点处(前提是执行到这个断点之前,程序都是正确的)。
在这里插入图片描述
执行完毕之后,就确实执行到了想要来的地方:
在这里插入图片描述

3. 查看变量信息,找出BUG

现在我们知道了怎么去调试,那对于上面代码的执行,我们充满疑惑,我们传参是5,但是结果输出却不是5,为什么?就让我们一探究竟!
在开始调试之后,点击工具栏调试–>窗口–>监视–>监视 1,打开一个监视窗口,这个窗口可以供我们监视程序中的变量:
在这里插入图片描述
点击监视之后,应该会出现下图所示的监视框:
在这里插入图片描述
我们在名称这个部位输入我们要监视的变量名Parameter:
在这里插入图片描述
当前程序还没执行 if 语句,我们看到Parameter中的值确实是我们传入的5,接下来F10,让它执行一步:
在这里插入图片描述
结果光标执行到了 if 语句的花括号内,然后Parameter的值发生了变化,变成了红色的7,红色意味着值发生改变。
那么我们明明执行的是判断语句,为什么最后好像成了赋值语句?
定睛一看!!! if 语句判断 少写了一个’=’,本来应该是if(Parameter == 7),于是我们对代码进行修改,完成了bug查找。

本篇有关调试的基础文章到此结束,学会调试的你,一定会在以后的查bug之路上,攻城拔寨,势如破竹!!如果学会了,喜欢博主的文章,可以一键三连支持博主,我们以后的日子里慢慢处!!

惯例,今日份吟诗一句:
“路遥知马力,日久见人心”

以上是关于学会调试,让你也成为改bug能手的主要内容,如果未能解决你的问题,请参考以下文章

十步让你成为更优秀的程序员

“八仙过海各传一招”,八招让你成为一名优秀的程序员!

学会如何调试程序bug

[调试逆向] 学会使用windbg定位程序bug

手写SpringMVC源码-梳理清楚这些你也能手写出来

手写SpringMVC源码-梳理清楚这些你也能手写出来