首先,super()函数指的是调用父类的构造方法
①
new B()
执行B的构造函数,第一行是super(5);
此时执行的是A的构造函数,A的构造函数调用的是setValue()方法,由于B重写了A的这个方法,
所以!!!执行的是B的 setValue()方法。
即传入的参数是2*5=10
此时,因为super,所以调用的是父类的 setValue()方法,即value=10
第一行执行完毕。
第二行是 setValue(getValue()-3);
B没有getValue()方法,故执行父类的此方法,
try返回的是value=10+1=11,保存在临时栈中
finally中调用this的方法,这个this指的是B的对象,又重写,故就是B的 setValue()方法
value=2*11=22,第一个打印到屏幕上的数字
接下来参数 getValue()-3=11-3=8
(try{ }中已经return了,所以这个方法的返回值已经保存下来)
字节码如下:
TRYCATCHBLOCK L0 L1 L2 java/lang/Exception
TRYCATCHBLOCK L0 L1 L3
TRYCATCHBLOCK L2 L4 L3
L0
LINENUMBER 15 L0
ALOAD 0
DUP
GETFIELD Test$A.value : I
ICONST_1
IADD
PUTFIELD Test$A.value : I
L5
LINENUMBER 16 L5
ALOAD 0
GETFIELD Test$A.value : I//取vlaue的值
ISTORE 3//先保存
L1
LINENUMBER 20 L1
ALOAD 0
ALOAD 0
GETFIELD Test$A.value : I
INVOKEVIRTUAL Test$A.setValue (I)V
L6
LINENUMBER 21 L6
GETSTATIC java/lang/System.out : Ljava/io/PrintStream;
ALOAD 0
GETFIELD Test$A.value : I
INVOKEVIRTUAL java/io/PrintStream.println (I)V
L7
LINENUMBER 16 L7
ILOAD 3//把保存的value取出
IRETURN//返回
传入B的 setValue()方法
此时value=2*8=16
至此,new B()执行结束
②
new B(). getValue()
B没有 getValue(),故执行A的 getValue()
try返回16+1=17,保存到临时栈中
finally调用B的 setValue()方法
value=17*2=34,第二个打印到屏幕上面的数字
最后主函数打印返回值,也就是try保存到临时栈的17
1
输出就是:22,34,17
class testp{
int x=1;
public testp() {
System.out.println(this.x);//this是父类对象
}
}
public class test extends testp{
int x=100;
public test() {
System.out.println(this.x);
}
public static void main(String args[]){
new test();
}
}
/*
输出:
1
100
*/
方法的重写后,调用父类方法要用super关键字显式调用(用this只会调用子类方法),而变量的隐藏后用this和super都行