解决Java常见Bug(二)
推荐
在线提问>>
3. 解决Bug整体思路
程序出Bug的时候, 我们最直接的感受是, 程序报错了.......
初学者这个时候就很慌, 哪里出问题了呢? 我该如何下手呢? 然后直接用眼睛一遍一遍的看代码, 想看出问题。其实这些都是错误的做法!!!
如果是几百行, 上千行代码, 将很难用眼睛看出问题.
所以解决Bug的整体思路是:
找到程序代码异常出现在第几行, 也就是哪一行代码的问题, 导致的Bug。
找到问题后, 修改就方便了. 其实改Bug主要是不容易找到Bug在哪里。
4. 发现解决Bug利器 - 日志
看错误日志, 虽然都是英文的, 可能有些小伙伴看不懂, 但是建议通读一遍, 看看是否有提示错误出现在第几行, 很多简单的问题, 日志上已经指定了哪个类, 第几行的错误。
下面大家看例子:
/**
* @author 健哥
*/
public class TestA {
int a = 1;
int b = 1;
public String sum() {
String total = "结果是:" + (a + b);
return total;
}
public static void main(String[] args) {
TestA a = new TestA();
int total = Integer.parseInt(a.sum());
System.out.println("=======" + total);
}
}
运行结果如下:

这样大家就可以清楚的看到, 错误日志中已经明显的告诉我们, 问题出在TestA.java这个类的第20行代码上, 我的第20行代码是:
int total = Integer.parseInt(a.sum());
原因是他的返回值是字符串并且包含中文, 我们强制转换类型为Integer, 结果抛出了类型转换异常。
