注意点:
提高程序的安全性,保护数据隐藏代码的实现细节统一接口系统可维护性增加了属性私有,get/set
super注意点:
super调用父类的构造方法,必须在构造方法的第一个super必须只能出现在子类的方法或者构造方法中super和this不能同时使用调用构造方法VS this:
代表的对象不同:
this: 本身调用者这个对象
super: 只能在继承条件下才可以使用
前提:
this:没有继承也可以使用
super:只能在继承条件下才可以使用
构造方法:
this();本类的构造
super();父类的构造
//父类 public class Person /*extends Object*/{ public Person() { System.out.println("Person执行了"); } } //子类 public class Student extends Person{ public Student() { super();//调用父类构造器,必须要在子类的第一行 //隐藏代码:调用了父类的无参构造 System.out.println("Student执行了"); } } //应用 public class Application { public static void main(String[] args) { Student student = new Student(); } }重写:需要有继承关系,子类重写父类的方法!
方法名必须相同参数列表必须相同修饰符:范围可以扩大但不能缩小 public>Protected>Default>private抛出的异常:范围可以缩小,但不能扩大 ClassNotFoundException–>Exception(大)重写,子类的方法和父类必须要一致:方法体不同!
为什么需要重写:
1. 父类的功能,子类不一定需要,或者不一定满足! 2. Alt+Insert ; override子类重写了父类的方法,执行子类的方法
即同一方法可以根据发送对象的不同而采用多种不同的行为方式一个对象的实际类型是确定的,但可以指向对象的引用的类型有很多多态存在的条件: 有继承关系子类重写父类方法父类引用指向子类对象多态注意事项:
多态是方法的多态,属性没有多态父类和子类,有联系 类型转换异常!ClassCastException!存在条件: 继承关系、方法需要重写,父类引用指向子类对象! Father f1 = new Son(); static 方法,属于类,它不属于实例final 常量private 方法 //父类 public class Person { public void run(){ System.out.println("run"); } } //子类 public class Student extends Person{ @Override public void run() { System.out.println("son"); } } //应用 public class Application { public static void main(String[] args) { //一个对象的实际类型是确定的 //new Student() //new Person() //可以指向的引用类型是不确定的:父类的引用指向子类 //Student 能调用的方法都是自己的或者继承父类的! Student s1 = new Student(); //Person 父类型,可以指向子类,但是不能调用子类独有的方法 Person s2 = new Student(); Object s3 = new Student(); s2.run();//子类重写了父类的方法,执行子类的方法 s1.run(); } }