本文主要是介绍写给大学生新手的查杀bug方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1947年9月9日,九九艳阳天,计算机历史上的第一个bug诞生了,我们之前在古今计算机发展简史(链接)中进行了比较详细的介绍。对于程序员来说,写bug、查bug、杀bug,都是司空见惯的事情。
我博客和公众号的关注者中,有不少是大学生朋友。经常有人给我发一段程序,让我帮找bug在哪里。非工作日且有空的话,我一般会回复:打log调试。仅举三例来看看:
大学生1:
大学生2:
大学生3:
有时候,问题确实比较简单,甚至一眼就可以看出来,但我也不会去直接指出来。授人以鱼不如授人以渔,我更希望他能自己调试出来,并有所进步。比如:
所以,就有了这篇文章。下次再有大学生朋友让你我帮找bug,就把这篇文章给他。顺便说一下,虽然大学生嘴里说大佬,但始终愧不敢当,我有自知之明,跟真正的大佬比,还差得远。
程序调试,是一个极为重要的能力。程序员,写出bug,也基本是见怪不怪了。在不同的场景下,需要用不同的方法来查杀bug.
在实际工作中,经常要用十八般武艺,综合使用或尝试多种方法,才能有效解决问题。客观来说,我自己查杀bug的经验和方法,应该还是比较丰富的。印象最深的是查出了一个linux系统的bug, 后来linux源码更新并发布新版本后,这个bug得到了解决。
然而,对于多数刚学程序的大学生来说,只需要掌握一招简单的方法,就可以搞定几乎所有的问题。方法就是: 打log调试。
我以之前收到的一段代码的简化示例版为例(原程序稍复杂一点):
#include <iostream>
using namespace std;int main()
{int a = 1;int b = 2;int c = 3;int *p = 0;*p = 0;int d = a + b + c;cout << d << endl;return 0;
}
那位大学生的问题是:为什么没有输出d的值,想知道错在哪里?
其实,如果运行这段程序,会有信息提示错在哪一行! 我现在假设他不知道怎么看提示信息,那该如何查问题在哪里呢?答案是:打log调试。如下:
#include <iostream>
using namespace std;int main()
{cout << "xxx1" << endl;int a = 1;cout << "xxx2" << endl;int b = 2;cout << "xxx3" << endl;int c = 3;cout << "xxx4" << endl;int *p = 0;cout << "xxx5" << endl;*p = 0;cout << "xxx6" << endl;int d = a + b + c;cout << "xxx7" << endl;cout << d << endl;cout << "xxx8" << endl;return 0;
}
输出结果是:
xxx1
xxx2
xxx3
xxx4
xxx5
这就奇怪了,有xxx5, 但没有xxx6, 所以错误必然是*p=0这里,这样就找到问题所在了。
总之,对于新手而言,打log调试,查看每一步,是最简单最可行的方法。如果这种方法还解决不了,我再看看是啥变异了的bug.
这篇文章很简单,不值一提,希望对大学生朋友有益。周五了,祝圣诞快乐,周末快乐。早休息!
这篇关于写给大学生新手的查杀bug方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!