java的继承和多态

1. super()和this ()都必须放在构造函数的第一行。

  • super是一块内存空间的唯一标识,但与this不同的是,this可以作为自身对象类型返回,而super不能作为父类类型返回。
  • 子类里的super内存空间,存的是父类的属性和方法的副本
  • 如果父类没有一个无参构造方法,那么子类必须通过super()调用有参构造方法。

2. 多态的方式创建对象-----> A a=new B()

  • 左边的类型(A)决定能a调用的方法,右边的类型(B)决定动态绑定时实际调用的方法
  • a.sayName()----->如果子类没有覆盖这个方法(sayName),就去父类找,父类里面没有,就去父类的父类找。
  • a不能调用父类的私有变量和方法。
  • 即使是父类方法里通过this调用其他方法,但实际绑定时this指向的是子类对象,调用的是子类方法
    //父类
	public class Fu extends SuperFu{
	   public void sayName(){
	       System.out.println("张三");
	       this.sayAge();
	   }
	   public void sayAge(){
	       System.out.println(26);
	   }
	}
	//子类
	public class Zi extends Fu {
    @Override
    public void sayName() {
        super.sayName();
    }

    @Override
    public void sayAge() {
        System.out.println("其实26岁");
    }
   }
   //打印结果
   张三
   其实26

3. 子类覆盖父类的方法,不可以用可见性更低的修饰符,可以用可见性更高的方法

  • 多态创建时:Fu fu=new Zi(),fu可调用的方法根据Fu决定,子类中对父类的覆盖方法如果用可见性更低的修饰符,那么fu就访问不了,与多态相矛盾
  • protected修饰的父类的属性和方法,子类可以跨包访问

4. 如类A extends B extends C, 当A,B,C作为方法重载的参数类型时,如: pubic void method(C c),public void method(B b)-------->此时传入A的实例时,会就近选择method(B b)。
5 .用final修饰类、属性和方法

  • 当修饰类时表示此类不可被继承
  • 当修饰静态变量、成员变量或者局部变量时,表示只能被赋值一次。--------.>public final A a=new A() ------>注意:修饰引用类型时,可以修改引用类型里(a)的属性,但不能对a这个变量二次赋值。
  • 不能修饰构造函数
  • 当修饰方法时,表示此方法不能被子类覆盖
  • 当修饰方法的形参时,方法体内不能再对这个形参赋值,只会在方法被调用时被赋值。

6. A extends B extends C : 都有静态方法say()-------->A a=new A()

  • 引用调用的静态方法只与引用的类型有关,与实际指向无关
  • a.say()调用的是A里面的静态方法
  • (B)a.say()调用的是B里面的静态方法
  • 一般直接用类调用静态方法,不推荐引用调用方法
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值