深度理解继承与多态

深度了解继承与多态。
继承,
效果:子类继承父类,子类对象可以调用父类的非不可调用成员属性(非private,或空权限修饰的成员)。
过程:初始化子类对象的过程:
父类静态代码块->子类静态代码块->父类代码块->父类构造方法->子类代码块->子类构造方法。
理解:
1.子类对象创建时并不会创建父类对象,只会访问父类的构造方法来初始化父类成员。在访问父类构造方法之前,父类的成员已经加载进内存了。
2.子类可以调用父类的成员是因为,初始化父类结束后,子类拥有了父类所有成员的拷贝包括private修饰的成员包括构造方法,就相当于子类在自己的内存空间中专门划分了一块来存放父类的成员。
3.this和super,this指向整个子类对象的内存空间包括父类成员的拷贝以及子类自身的成员。而super指向的则是子类中对父类成员拷贝的部分。(说到这里第二点拥有父类所有成员相信大家就理解了)
综上所述,super与this其实都是指向子类的对象的内存空间。

多态:
效果:Father f=new Son();父类的引用指向子类的对象。
创建的对象f调出的成员属性是父类的,但调出的成员方法是子类的。也就是我们所谓的,多态中方法具有多态性,而属性不具有多态性。
理解:java在编译时,是静态绑定的。也是就是说,在编译时,为了不报错,对象f被认为就是father的对象。f表现出的属性就是Father的。但是在运行时java是动态绑定的。此时f的引用是指向Son对象的。所以方法运行时是调用的子类的方法。而且它的属性也是子类的。举个例子。

Father f=new Son();
在f对象的方法中调用子类父类共有的属性会怎么样呢?
出来的结果是:属性值是子类的属性值

示例代码:因为自己电脑不再身边所以用记事本写的
public class Main{
public static void main(String [] args){
Father f = new Son();
System.out.println(“成员变量”+f.a+f.age);//结果为"爸爸"+1
f.get();//结果为爸爸+儿子
}

}
abstract class Father{
public String age = “爸爸”;
public int a;
Father(){
a=1;
System.out.println(“爸爸的构造”+“hhh”+age);

System.out.println(a);
}
abstract void get();
}

class Son extends Father{
public String age =“儿子”;
public int b=1;
public Son(){
super();
}
public void get(){
System.out.println(super.age+age);

}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值