s2:|写给大学生新手的查杀bug方法

原文发表于公众号:涛歌依旧(扫描二维码,关注公众号,免费领资料)
s2:|写给大学生新手的查杀bug方法
文章图片


1947年9月9日,九九艳阳天,计算机历史上的第一个bug诞生了,我们之前在古今计算机发展简史(链接)中进行了比较详细的介绍。对于程序员来说,写bug、查bug、杀bug,都是司空见惯的事情。
我博客和公众号的关注者中,有不少是大学生朋友。经常有人给我发一段程序,让我帮找bug在哪里。非工作日且有空的话,我一般会回复:打log调试。仅举三例来看看:

大学生1:
s2:|写给大学生新手的查杀bug方法
文章图片


大学生2:
s2:|写给大学生新手的查杀bug方法
文章图片


大学生3:
s2:|写给大学生新手的查杀bug方法
文章图片


有时候,问题确实比较简单,甚至一眼就可以看出来,但我也不会去直接指出来。授人以鱼不如授人以渔,我更希望他能自己调试出来,并有所进步。比如:
s2:|写给大学生新手的查杀bug方法
文章图片


所以,就有了这篇文章。下次再有大学生朋友让你我帮找bug,就把这篇文章给他。顺便说一下,虽然大学生嘴里说大佬,但始终愧不敢当,我有自知之明,跟真正的大佬比,还差得远。
程序调试,是一个极为重要的能力。程序员,写出bug,也基本是见怪不怪了。在不同的场景下,需要用不同的方法来查杀bug.
在实际工作中,经常要用十八般武艺,综合使用或尝试多种方法,才能有效解决问题。客观来说,我自己查杀bug的经验和方法,应该还是比较丰富的。印象最深的是查出了一个linux系统的bug, 后来linux源码更新并发布新版本后,这个bug得到了解决。
s2:|写给大学生新手的查杀bug方法
文章图片


然而,对于多数刚学程序的大学生来说,只需要掌握一招简单的方法,就可以搞定几乎所有的问题。方法就是: 打log调试。
我以之前收到的一段代码的简化示例版为例(原程序稍复杂一点):

#include 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的值,想知道错在哪里?

【s2:|写给大学生新手的查杀bug方法】其实,如果运行这段程序,会有信息提示错在哪一行! 我现在假设他不知道怎么看提示信息,那该如何查问题在哪里呢?答案是:打log调试。如下:
#include 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.

这篇文章很简单,不值一提,希望对大学生朋友有益。周五了,祝圣诞快乐,周末快乐。早休息!

    推荐阅读