基类的方法(如此例中Base的构造函数)继承到子类后(如果没有被覆盖),方法体中调用的方法将是子类覆盖后的方法,而方法体中访问的变量仍是基类的变量,如果基类的变量被隐藏了,则认为该变量为0。因此在new Extension()时,首先因为调用基类的构造函数,而执行的是子类add(3),同时由于基类的j变量被覆盖了而被当作是0,因此add(3)后,i=3*3+0,所以输出:In base,i:9。接着执行子类自己的构造函数,执行add(2),此时访问的变量就是子类自己的了,因此9+2*3+4=19,所以输出:In Extension,i:19。最后执行b.add(6)。因为b实际引用的Extension类型的对象,因此执行的也就是子类的add()方法,从而得到:19+6*3+4=41。因此最后有i=41。 |
温馨提示:喜欢本站的话,请收藏一下本站!