0420_宋红康笔记(day11-13)(多态、重写重载、super、子类对象实例化、转型、装箱、equals)

23 篇文章 0 订阅
  • 多态
    多态的使用:虚拟方法调用
  • 有了对象的多态性以后,我们在编译期,只能调用父类中声明的方法,但在运行期,我们实际执行的是子类重写父类的方法。
    总结:编译,看左边;运行,看右边。
  • 多态性的使用前提: ① 类的继承关系 ② 方法的重写
    对象的多态性,只适用于方法,不适用于属性(编译和运行都看左边)
  • 封装性解决的是能不能调的问题,继承性解决的是能不能获取的问题。子类能够获取父类中private权限的属性或方法。子类想调用它们,可以间接调用(getXxx,把private方法放在public方法中),这也间接证明了能够获取。
  • 方法的重写和重载的区别:
  • 规则:方法重写是权限修饰符相同、返回值相同、方法名相同、参数列表相同、方法体不同;方法重载是权限修饰符相同、返回值相同、方法名相同、参数列表不同、方法体相同。
  • 概念:方法重写是子类对父类方法进行的操作;方法重载是在一个类中定义多个重名方法。
  • 从编译和运行的角度看:从编译和运行的角度看:
    重载不表现为多态性;重写表现为多态性。
    重载,是指允许存在多个同名方法,而这些方法的参数不同。编译器根据方法不 同的参数表,对同名方法的名称做修饰。对于编译器而言,这些同名方法就成了 不同的方法。它们的调用地址在编译期就绑定了。Java的重载是可以包括父类 和子类的,即子类可以重载父类的同名不同参数的方法。 所以:对于重载而言,在方法调用之前,编译器就已经确定了所要调用的方法, 这称为“早绑定”或“静态绑定”;
    而对于多态(重写),只有等到方法调用的那一刻,解释运行器才会确定所要调用的具体方法,这称为“晚绑定”或“动态绑定”。
    引用一句Bruce Eckel的话:“不要犯傻,如果它不是晚绑定,它就不是多态。”

注意: 子类和弗雷中的同名通擦书的方法要么都声明为非static的(考虑重写),要么都声明为static的(不是重写)。

  • super的使用:调用属性和方法
  • 我们可以在子类的方法或构造器中。通过使用"super.属性"或"super.方法"的方式,显式的调用父类中声明的属性或方法。但是,通常情况下,我们习惯省略"super."
  • 特殊情况:当子类和父类中定义了同名的属性时,我们要想在子类中调用父类中声明的属性,则必须显式的使用"super.属性"的方式,表明调用的是父类中声明的属性。
  • 特殊情况:**当子类重写了父类中的方法以后,我们想在子类的方法中调用父类中被重写的方法时,则必须显式的使用"super.方法"的方式,**表明调用的是父类中被重写的方法。
  • 子类对象实例化过程
    在这里插入图片描述
  • 多态的使用:虚拟方法调用
    有了对象的多态性以后,我们在编译期,只能调用父类中声明的方法,但在运行期,我们实际执行的是子类重写父类的方法。
    总结:编译,看左边;运行,看右边。
  • 向下转型:
    应用:被多态化的对象往往不能使用子类特有的方法,将其向下转型转回子类类型后就可以了。
    在这里插入图片描述
    instanceof: 关键字的使用
    a instanceof A:判断对象a是否是类A的实例。如果是,返回true;如果不是,返回false。
    使用情境:为了避免在向下转型时出现ClassCastException的异常,我们在向下转型之前,先
    进行instanceof的判断,一旦返回true,就进行向下转型。如果返回false,不进行向下转型。
    如果 a instanceof A返回true,则 a instanceof B也返回true.其中,类B是类A的父类。
  • Object类
  • = =: 如果比较的数据是基本数据类型,则比较的是他们的值是否相等(不同类型之间存在类型自动提升,所以除了boolean类型以外的类型之间都可以互相比较 char c=10; int i=10; syso(c==i);//true)
  • equals(): 只适用于引用数据类型(因为基本数据类型不属于对象,点不出来);对于重写了equals()的类,如String(), Date() 等,比较的是实际内容是否相同,对于没重写equals()的类,使用的就是Object原有的equals()方法,它与==作用相同,比较多是引用类型数据地址值相同与否,可以在该类中对其进行重写。
  • 普通方法中可以直接调属性,静态方法里必须通过对象调。
  • 包装类:
  1. 基本数据类型—>包装类类型:为了能够让基本数据类型的数据使用引用数据类型能够使用的方法(作为形参被声明在方法中;调属性等等)int num1=10; Integer in1=new Integer(num1); syso(int1.toString());
    int num1=10; Integer int1=num1; syso(in1.toString());

自动装箱:int num1=10; Integer in1=num1;

  1. 包装类类型—>基本数据类型:进行基本运算
    Integer in2=new Integer(10); int num2= in2.intValue(); syso(num2+1);

自动拆箱:int num1=in1; syso(num1+1);

  • Integer内部定义了IntegerCache结构。其中定义了一个Integer[],保存了从-128+127范围的整数,如果使用自动装箱的方式,给Integer赋值的范围在-128+127范围内时,可以直接使用数组中的元素,不用再去new了,用完后元素也不会被销毁,可以提高Integer装箱效率。
  • 基本数据类型与字符串类型数据之间的转换:
    在这里插入图片描述

基—>字:valueOf(Xxx xx)
字—>基:parseXxx(String s)

  • JUnit的作用:
  • 引用类型的数据:类、数组(算一种特殊的类,也继承于Object)、接口
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值