“子类可以直接访问弗雷中定义的成员变量和方法”这种介绍其实稍显笼统
JAVA继承中対成员变量和方法的处理不同
代码如下
class Base
{
int count = 2;
public void display()
{
System.out.println(this.count);
}
}
class Derived extends Base
{
int count = 20;
@Override
public void display()
{
System.out.println(this.count);
}
}
public class FieldTest
{
public static void main(String[] args)
{
Base b = new Base();
System.out.println(b.count);
b.display();
Derived d = new Derived();
System.out.println(d.count);
d.display();
Base bd = new Derived();
System.out.println(bd.count);
bd.display();
Base d2b = d;
System.out.println(d2b.count);
d2b.display();
}
}
运行结果
我的预期结果 | 2 | 2 | 2 | 20 | 2 | 2 | 2 | 20 |
实际运行结果 | 2 | 2 | 20 | 20 | 2 | 20 | 2 | 20 |
学习心得
第6列答案:
bd访问count实例变量 输出的将是Base对象的count实例变量值
bd调动display() 将表现出Derived运行时对象的行为方式
【转】Java中@Override的作用
@Override是伪代码,表示重写(当然不写也可以),不过写上有如下好处:
1、可以当注释用,方便阅读;
2、编译器可以给你验证@Override下面的方法名是否是你父类中所有的,如果没有则报错。例如,你如果没写@Override,而你下面的方法名又写错了,这时你的编译器是可以编译通过的,因为编译器以为这个方法是你的子类中自己增加的方法。
举例:在重写父类的onCreate时,在方法前面加上@Override 系统可以帮你检查方法的正确性。
@Override
public void onCreate(Bundle savedInstanceState)
{…….}
这种写法是正确的,如果你写成:
@Override
public void oncreate(Bundle savedInstanceState)
{…….}
编译器会报如下错误:The method oncreate(Bundle) of type HelloWorld must override or implement a supertype method,以确保你正确重写onCreate方法(因为oncreate应该为onCreate)。而如果你不加@Override,则编译器将不会检测出错误,而是会认为你为子类定义了一个新方法:oncreate