天天看点

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

1947年9月9日,九九艳阳天,计算机历史上的第一个bug诞生了,我们之前在古今计算机发展简史(链接)中进行了比较详细的介绍。对于程序员来说,写bug、查bug、杀bug,都是司空见惯的事情。

我博客和公众号的关注者中,有不少是大学生朋友。经常有人给我发一段程序,让我帮找bug在哪里。非工作日且有空的话,我一般会回复:打log调试。仅举三例来看看:

大学生1:

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

大学生2:

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

大学生3:

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

有时候,问题确实比较简单,甚至一眼就可以看出来,但我也不会去直接指出来。授人以鱼不如授人以渔,我更希望他能自己调试出来,并有所进步。比如:

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

所以,就有了这篇文章。下次再有大学生朋友让你我帮找bug,就把这篇文章给他。顺便说一下,虽然大学生嘴里说大佬,但始终愧不敢当,我有自知之明,跟真正的大佬比,还差得远。

程序调试,是一个极为重要的能力。程序员,写出bug,也基本是见怪不怪了。在不同的场景下,需要用不同的方法来查杀bug.

在实际工作中,经常要用十八般武艺,综合使用或尝试多种方法,才能有效解决问题。客观来说,我自己查杀bug的经验和方法,应该还是比较丰富的。印象最深的是查出了一个linux系统的bug, 后来linux源码更新并发布新版本后,这个bug得到了解决。

写给大学生新手的查杀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.

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

继续阅读