public class Test {
public static void main(String [] args){
System.out.println(new B().getValue());
}
static class A{
protected int value;
public A (int v){
setValue(v);
}
public void setValue(int value){
this.value = value;
}
public int getValue(){
try{
value++;
return value;
}finally{
this.setValue(value);
System.out.println(value);
}
}
}
static class B extends A{
public B(){
super(5);
setValue(getValue()-3);
}
public void setValue(int value){
super.setValue(2*value);
}
}
}
分析:
第一步实例化B,B构造方法中执行父类A构造方法,调用setValue()方法,由于子类中存在这个方法,所以调用子类的setValue()方法,子类的setValue()方法执行父类的setValue()方法,此时父类A成员变量value为10;然后继续执行B类中的构造方法setValue(getValue()-3);由于子类没有getValue(),所以调用父类的此方法,value为11,return;由于finally,最终会执行,this.setValue()属于子类的方法,故value为11 * 2,即打印22;由于finally没有return,所以不会覆盖try中的return值,即getValue()返回11,即setValue(11-3);
重复上述操作,A类成员变量此时变为16,然后调用new B().getValue();由于B类没有此方法,故调用A类此方法,value为17,return;由于finally,最终会执行,this.setValue()属于子类方法,故value为17 * 2,即打印34;由于finally没有return,所以不会覆盖try中的return值,最终打印main方法中getValue()值,即17,所以最终控制台打印22 34 17。