课后动手动脑
1、动手动脑:继承条件下的构造方法调用
首先执行超类的构造方法,然后显示子类的构造方法。
当修改代码后,执行结果变为:
依旧会先执行超类的构造方法,然后执行字类的相对应的构造方法。
思索:
由于子类是继承父类中的属性的,而父类中的属性需要调用父类的构造方法进行初始化,所以每次新定义一个子类的对象时,都需要调用一次父类的构造函数。所以不能将这个过程反过来,因为继承是顺序继承,不可逆。
2、探索技术的奥秘
首先,haha.a是对象类的名字,haha是包的名字,a是类的名字,@后...这些是开辟的新地址,因为每次初始化对象,都需要给新的对象开辟新的空间,所以这就需要不同的地址来存储数据了。
3、动手动脑:方法覆盖
代码:
//信1605-2 20163576 蔡逸飞;
package haha;
class haha
{
void en()
{
System.out.println("haha");
}
}
class ha extends haha
{
void en()
{
super.en();
System.out.println("ha");
}
}
public class tiaoshi
{
public static void main(String args[])
{
ha h1=new ha();
h1.en();
}
}
结果:
在没有super的情况下,只会输出ha,也就是子类的类名,而父类中的方法,由于方法覆盖不能够显示出结果,但是当加上super语句后,就可以执行父类中的重名方法了。
4、“类型转换”知识点考核-2
第二、四和五都会出现问题。
由于dog中的属性比mammal中的属性多,所以mammal转换为dog类型时,就会出现问题。
而dog与cat的属性不一样,所以不能相互赋值。
而m并没有得到cat的赋值,多以并不能直接将m转换为cat类型。
5、在实践中理解把握复杂的知识-2
结果:
初始化parent和child并调用方法,执行结果为前两行,
当将child赋值给parent后,调用parent的方法,输出的是child的值,应当是parent中的重名方法和属性被child的覆盖,然后输出地值就是child的值了,然后将parent的属性值加1,但由于此时parent的方法输出地是child的属性,所以为200,最后将parent强制转换为child类型使他的值加1,最后调用方法,输出201。