Java中子类和父类之间的调用关系

来源:互联网 发布:针锋对决网络剧第一集 编辑:程序博客网 时间:2024/06/10 09:27


在讲之前,一些基本知识是应该具备的:

1.如果一个类中没有定义构造器,编译器在编译时会自动加上默认无参构造器:

public ClassName {}

2. this 和 super 的区别。

3.每个类直接或间接是Object的子类,Object只有一个无参构造方法。

4.编译器会在每个构造方法的第一行隐式添加父类的默认无参构造器,即添加super()。


新手容易犯的错误:


class Employee extends Object {public Employee(int id) {}}class Teacher extends Employee {public Teacher() {}}

以上代码会产生编译错误:

Implicit super constructor Employee() is undefined. Must explicitly invoke another constructor
因为父类定义了一个带参数的构造器,因此编译器不会添加默认无参构造方法,但是因为在子类的构造器中没有显式调用父类的某个构造方法,因此编译器会自动添加super()方法, 但是父类中不存在默认无参构造方法,因此会提示默认无参构造方法未定义错误。


修改后的代码:

class Employee {public Employee(int id) {}}class Teacher extends Employee {public Teacher() {super(10);}}

这样,在子类的构造器中显式调用了父类的某个构造器,所以编译器不会自动添加super()方法。


构造器的访问修饰符:

一般可以用public,protected,default和private修饰,但是对于private,子类是无法调用该类构造器的。


多层次调用父类构造方法:

假设我们有这样一个层次结构:

Object->Employee->Teacher->Professor


class Employee {public Employee() {System.out.println("Employee constructor called");}}class Teacher extends Employee {public Teacher() {System.out.println("Teacher constructor called");}}class Professor extends Teacher {public Professor() {System.out.println("Professor constructor called");}}public class Test {public static void main(String args[]) {Employee p = new Professor();}}

打印结果:

Employee constructor calledTeacher constructor calledProfessor constructor called

在创建Professor对象时(new Professor()),首先会找到该类的无参构造方法,然后首先调用super()方法,调用Teacher类的无参构造方法,接着再调用Employee的无参构造方法,最后再调用Object的无参构造方法。最后再打印出信息。