-
this调用的结构:属性、方法;构造器
-
this调用属性或方法时,理解为:当前对象或当前正在创建的对象。
public void setName(String name){ //当属性名和形参名同名时,必须使用this来区分 this.name = name; } public Person(String name){ this.name = name; }
-
this(形参列表)的方式,表示调用当前类中其他的重载的构造器。
- 继承性的好处
- 减少了代码的冗余,提高了复用性;
- 提高了扩展性
- 为多态的使用,提供了前提。
- Java中继承性的特点
- 局限性:类的单继承性。后续我们通过类实现接口的方式,解决单继承的局限性。
- 支持多层继承,一个父类可以声明多个子类。
- 基础:class A extends B{}
- 理解:子类就获取了父类中声明的全部的属性、方法。可能受封装性的影响,不能直接调用。
- 面试题:方法的重载与重写的区别?
- 方法的重载:“两同一不同”
- 方法的重写:
- 前提:类的继承关系
- 子类对父类中同名同参数方法的覆盖、覆写。
- super可以调用的结构:属性、方法;构造器
- super:父类的
- super调用父类的属性、方法:
- 如果子父类中出现了同名的属性,此时使用super.的方式,表明调用的是父类中声明的属性。
- 子类重写了父类的方法。如果子类的任何一个方法中需要调用父类被重写的方法时,需要使用super.
- super调用构造器:
- 在子类的构造器中,首行要么使用了"this(形参列表)",要么使用了"super(形参列表)"。
- 结果上来说:体现为继承性
- 过程上来说:子类调用构造器创建对象时,一定会直接或间接的调用其父类的构造器,以及父类的父类的构造器,...,直到调用到Object()的构造器。
-
广义上的理解:子类对象的多态性、方法的重写;方法的重载
狭义上的理解:子类对象的多态性。
-
格式:Object obj = new String("hello"); 父类的引用指向子类的对象。
-
多态的好处:减少了大量的重载的方法的定义;开闭原则
- 举例:public boolean equals(Object obj)
- 多态,无处不在!讲了抽象类、接口以后,会有更好的理解。
-
多态的使用:虚拟方法调用。“编译看左边,运行看右边”。属性,不存在多态性。
-
多态的逆过程:向下转型,使用强转符()。
- 为了避免出现强转时的ClassCastException,建议()之前使用instanceOf进行判断。
- 根父类
- equals()的使用
- 重写和不重写的区别
- 面试题: == 和 equals()
- toString()的使用
- Object中toString()调用后,返回当前对象所属的类和地址值。
- 开发中常常重写toString(),用于返回当前对象的属性信息。
- 编写两个类:Customer 、 CustomerList类(封装了对数组的增删改查操作)
父类的属性、方法可以被继承。构造器可以被子类调用。
略
public void method(int i){}
public int method(int j,int k){}
不能!构造器可以重载
见名知意。
把两个关键字各自的特点说清楚。
略
类似问法:
> Java中实现多态的机制是什么(国*电网)
> 什么是多态?(上*银行)
> Java中的多态是什么意思?(贝*)
略
Person p = new Man(); //虚方法调用。屏蔽了子类Man类特有的属性和方法。
Man m = new Man();
无处不在!
略
类似问法:
> 两个对象A和B,A==B,A.equals(B)有什么区别(华油**普)
略
- 明确判定两个对象实体equals()的标准。是否需要所有的属性参与。
- 对象的属性,又是自定义的类型,此属性也需要重写equals()
相关问题:
> Object类有哪些方法?(恒*电子)