JAVA继承中子父类的构造方法

首先,构造方法本身会有一个隐式的无参构造(认):

①不写构造方法,类中的第一行代码事实上有一个认的无参构造(系统会隐式为你写好)

public class Student {
        private String name;
//        public Student() {}      隐式地“写”在这里,你看不见
//  Strudent类中虽然没有写构造方法,但相当于有上面的无参构造
//   只不过是隐式的,你看不见
}

(推荐视频:java教程

②只写带参构造方法,相当于只有该带参构造方法(隐式的无参构造会被屏蔽无视掉,视为无效)

public class Student {
        private String name;
        public Student(String name) {
            this.name=name;
        }
//  此时原来Strudent类中的隐式的无参构造方法屏蔽了,无效了
//  类中只有带参构造
}

③若想同时拥有无参和带参构造,必须显式地写出无参和带参构造方法

public class Student {
        private String name;
        public Student() {}
// 显式地将无参构造写出来        
        public Student(String name) {
            this.name=name;
        }
//  若想Strudent类中拥有无参构造方法,必须显式地写出来
}

进一步结合继承,就需要考虑到子父类:

④在子类的构造方法(无论是无参和有参)中,方法中的第一行代码事实上都隐式地包含了父类的无参构造方法

即: super()

public class Stu extends Student {
    private String name;
    public Stu() {
    // super();
    // 在子类的无参构造中,super()是隐式的“写”在这里的
    }
    
    public Stu(String name) {
    // super();
    this.name=name;
    // 在子类的带参构造,上面的super()同样也是隐式的“写”在这里的
    }
}

这就是为什么,调用子类的构造方法时,都会先调用父类的无参构造方法了,因为认的super()存在。

⑤同理,类似与上面的②,此时若写一个有参构造,super(xx)会把隐式的super()屏蔽

public class Stu extends Student {
    private String name;
    
    public Stu(String name) {
    // super();  原来隐式写在这里super()屏蔽了,无效了
    super(name);
    
    // 在子类的带参构造, 由于的super(name)的存在,super()无效了
    //此时子类的带参构造中,只有super(name)
    }
}

这就是为什么当父类没有无参构造(即只有带参构造——对应情况②)时,子类的构造方法编译无法通过。这是因为子类的构造函数(带参或无参)将调用父类的无参构造函数。 由于编译器试图向子类中的2个构造函数中插入super() ,但父类认构造函数未定义,因此编译器会报告错误消息。

解决这个问题,只需要

1)添加一个无参构造函数父类——显式地在父类添加无参构造

2)删除父类自定义的有参构造函数——等价于恢复了认的无参构造

3)将 Super(XXX) 添加到子类构造函数——通过⑤的原来来屏蔽认的super()

本文来自编程之家网,java教程栏目,欢迎学习!

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...