解析java在的debug模式之属性断点调试

1 原理

停顿在读写属性的代码行

2 使用步骤

2.1 在类体中的属性代码行处选择合适的位置进行左键单击,属性断点的图标是眼睛形状。当出现眼睛形状时,意味着属性断点打上成功

2.1.1 打属性断点的位置

java如何debug看值 java debug修改值_java

2.1.2 打完属性断点之后的效果图

java如何debug看值 java debug修改值_调试程序必备技巧_02

2.2 右键在眼睛图标上单击,弹出一个选项菜单,默认是勾选field modification(属性修改),我们需要手动勾选field acess(属性获取)

java如何debug看值 java debug修改值_java如何debug看值_03

2.3 点击debug调试模式后,会停顿在修改属性的那一行(先调用构造方法进行初始化赋值)

2.3.1 点击debug调试模式

java如何debug看值 java debug修改值_java_04

2.3.2 点击debug调试模式后

java如何debug看值 java debug修改值_属性断点_05

2.4 点击resume program后,会停顿在下一次属性读写的方法的首行

java如何debug看值 java debug修改值_debug模式_06

3 使用场景

你需要监测属性的读写情况的时候用

4 示例代码

Dog类

package Work;
public class Dog {
    private String name;
    //名字
    private String type;
    //类型
    private int age;
    //年龄

    public Dog() {
    }

    public Dog(String name, String type, int age){
        this.name = name;
        this.type = type;
        setAge(age);
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getType() {
        return type;
    }

    public void setType(String type) {
        this.type = type;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age){
        if(age<0||age>10){
            System.out.println("年龄非法");
        }
        this.age = age;
    }

    @Override
    public String toString() {
        return "Dog{" +
                "name='" + name + '\'' +
                ", type='" + type + '\'' +
                ", age=" + age +
                '}';
    }
}

Person类

package Work;
public class Person {
    private String name;
    //有一个Dog类型的属性
    private Dog dog;

    public Person(String name, Dog dog) {
        this.name = name;
        this.dog = dog;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Dog getDog() {
        return dog;
    }

    public void setDog(Dog dog) {
        this.dog = dog;
    }

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", dog=" + dog +
                '}';
    }
}

Test05类

package Work;
public class Test05 {
    public static void main(String[] args) {
       //检测传入的引用数据类型里面的具体参数变化
      Person p=new Person("张三",new Dog("德福","金毛",7));
       p.getDog().setAge(10);
    }

}

5 示例代码debug模式截图

5.1 在引用类型的属性左侧点上属性断点并勾上Field access

java如何debug看值 java debug修改值_debug模式_07

勾选上Field Access

java如何debug看值 java debug修改值_debug模式_08

5.2 点击debug模式后会跳转到该属性第一次读写的位置

java如何debug看值 java debug修改值_java如何debug看值_09

5.3 点击resume program,会跳转到下一次属性读写的位置

java如何debug看值 java debug修改值_属性断点_10

5.4 再点击resume program,发现后面已经读写属性了,程序就会按照正常的逻辑将后面的代码跑完

前提条件

java如何debug看值 java debug修改值_调试程序必备技巧_11

因此,第二次点击resume program的效果如下所示

java如何debug看值 java debug修改值_java_12