Eclipse调试的三个小技巧

1.设置条件断点

项目异常中止后,总也找不到原因,在项目中应用了第三方类库的时候更可能发生这种情况。这种情况的原因有可能是代码中catch了异常但是没有做任何处理(最可恨的是还屏蔽了打印错误信息)。
下面以简短的例子进行说明

public class User{
    int id;
    String name;

    public User(int id, String name) {
        this.id = id;
        this.name = name;
    }
    public User(){

    }
//getXX ignore there
//setXX ignore there
}
public static void main(String[] args) {

        User userEmpty = new User();
        userEmpty = null;
        User user0 = new User(23, "12321");
        try {
            if (userEmpty.equals(user0)) {
                System.err.println("");
            }
        } catch (Exception e) {
// e.printStackTrace();
        }
        }

这样一块代码,直接运行,异常终止,但是没有任何错误信息。调试这样的错误可能就有些麻烦了。如果使用条件断点,就会“柳暗花明”。
Eclipse中进入debug View,然后如下图所示,点击“Add java Breakpoint Exception”Eclipse调试的三个小技巧_第1张图片
在弹出的对话框中输入NullPointerExcetion,点击确定。
再次运行
Eclipse调试的三个小技巧_第2张图片
ok!,找到问题出处了。

2.查看对象的具体信息(这里不重写bean的toString())

将Main方法修改为如下内容:

public static void main(String[] args) {

        User user0 = new User(23, "12321");

        Map<String, User> userMap=new HashMap<String,User>();
        userMap.put("0", user0);
        System.err.println();
}

在打印空信息的那一行打下断点,运行查看map信息如下:
Eclipse调试的三个小技巧_第3张图片
即使将每一个节点都展开,也不能看到user0的id和name信息。下面点击Variable View中的“Show Logical Structure”,如下图所示:
Eclipse调试的三个小技巧_第4张图片
再次运行程序,查看变量
Eclipse调试的三个小技巧_第5张图片
ok,用户信息出现了!

3.动态修改变量的值

将Main函数修改为如下内容:

    public static void main(String[] args) {

        User user0 = new User(23, "12321");
        System.err.println();
        System.err.println(user0);
        }

打印空信息的那一行打上一个断点,debug查看信息:
Eclipse调试的三个小技巧_第6张图片
然后如下图所示,在Variables View中user0对象的name属性上右键单击选择“Change Values”,输入“erhuo”,确定。
Eclipse调试的三个小技巧_第7张图片
F6单步调试,查看结果
Eclipse调试的三个小技巧_第8张图片
ok,修改变量信息成功!

参考文章:

Effective Java Debugging with Eclipse

你可能感兴趣的:(eclipse)