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里面的静态方法
- 一般直接用类调用静态方法,不推荐引用调用方法