标签:out 构造方法 无法 多态 因此 pac 直接 调用 初始化
1. 为什么子类的构造方法在运行之前,必须调用父类的构造方法?能不能反过来?为什么不能反过来?
构造方法在创建对象时被调用,用来初始化新对象,即为对象成员变量赋初值。子类要继承父类的成员变量和方法,如果不调用父类的构造方法,那么父类的成员变量和成员方法无法在子类创建对象时正确初始化。反过来调用不可以,因为父类不知道子类有什么变量,这样子类也得不到初始化的父类变量。
2.请自行编写代码测试以下特性,在子类中,若要调用父类中被覆盖的方法,可以使用super关键字。
package practice;
public class UseSuperInherits
{
public static void main(String[] args)
{
Child c=new Child();
c.printValue();
}
}
class Parent
{
public int value=100;
public void printValue()
{
System.out.println("parent.value="+value);
}
}
class Child extends Parent
{
public int value=200;
public void printValue()
{
System.out.println("child.value="+value);
super.printValue();
}
}
运行结果截图:
3.“类型转换”知识点考核
下列语句哪一个将引起编译错误?为什么?哪一个会引起运行时错误?为什么?
m=d;
d=m;
d=(Dog)m;
d=c;
c=(Cat)m;
先进行自我判断,得出结论后,运行TestCast.java实例代码,看看你的判断是否正确。
m=d; ture
d=m; false
d=(Dog)m; true
d=c; false
c=(Cat)m; true
测试结论:
d=m;和d=c;会引起编译错误,c=(Cat)m;会引起运行错误,编译错误因为子类对象可以直接赋给基类对象变量,基类对象要赋给子类对象变量,必须执行类型转换;运行错误因为基类对象变量m已经强制转化成Dog类对象变量,而Dog类与Cat类不存在子父类关系,不能强制类型转化。
4.在实践中理解把握复杂的知识
(1)左边的程序运行结果是什么?
(2)你如何解释会得到这样的输出?
(3)计算机是不会出错的,之所以得到这样的运行结果也是有原因的,那么从这些运行结果中,你能总结出Java的哪些语法特性?
运行结果截图:
运行结果原因:
第一行与第二行:分别创建子类和父类的对象,并调用各自的方法。
第三行:将子类对象child赋值给父类对象parent,父类对象parent的属性值不变,只是将父类的同名方法覆盖,所以当父类对象parent只能调用子类的printValue()方法,又因为子类方法访问的是子类中的字段而不是父类,所以输出子类对象parent的myValue属性值200。
第四行:parent.myValue++是将父类对象parent的属性myValue++,变为101,但是父类对象parent调用方法时调用的还是子类的printValue()方法,子类方法访问的还是子类中的字段,所以输出子类对象child的myValue属性值200。
第五行:把父类对象parent强制类型转换成子类Child类型,此时对象parent的为子类对象,拥有子类的属性和方法,因此((Child)parent).myValue++后,parent的myValue的属性值变为201,输出结果201。
Java特性总结:
1.当子类与父类拥有一样的方法,并且让一个父类变量引用一个子类对象时,到底调用哪个方法,由对象自己的“真实”类型所决定,这就是说:对象是子类型的,它就调用子类型的方法,是父类型的,它就调用父类型的方法。
2.如果子类与父类有相同的字段,则子类中的字段会代替或隐藏父类的字段,子类方法中访问的是子类中的字段(而不是父类中的字段)。如果子类方法确实想访问父类中被隐藏的同名字段,可以用super关键字来访问它。
3.如果子类被当作父类使用,则通过子类访问的字段是父类的。
标签:out 构造方法 无法 多态 因此 pac 直接 调用 初始化
原文地址:http://www.cnblogs.com/iCheny/p/7814990.html