Java中的构造函数继承

Python024

Java中的构造函数继承,第1张

专家读书笔记 希望能够对大家学习java有所帮助

每个子类构造方法的第一条语句 都是隐含地调用super() 如果父类没有这种形式的构造函数 那么在编译的时候就会报错

这句话怎么理解

所有代码都经过测试 测试环境

java   version   rc

Java(TM)      Runtime   Environment    Standard   Edition   (build   rc b )

Java   HotSpot(TM)   Client   VM   (build   rc b    mixed   mode)

如大家发现任何错误 或有任何意见请不吝赐教

缺省构造函数的问题 base类是父类 derived类是子类 首先要说明的是由于先有父类后有子类 所以生成子类之前要首先有父类

class是由class的构造函数constructor产生的 每一个class都有构造函数 如果你在编写自己的class时没有编写任何构造函数 那么编译器为你自动产生一个缺省default构造函数 这个default构造函数实质是空的 其中不包含任何代码 但是一牵扯到继承 它的问题就出现了

如果父类base   class只有缺省构造函数 也就是编译器自动为你产生的 而子类中也只有缺省构造函数 那么不会产生任何问题 因为当你试图产生一个子类的实例时 首先要执行子类的构造函数 但是由于子类继承父类 所以子类的缺省构造函数自动调用父类的缺省构造函数 先产生父类的实例 然后再产生子类的实例 如下

class   base{

}

class   derived   extends   base{

public   static   void   main(String[]   args){

derived   d=new   derived()

}

}

下面我自己显式地加上了缺省构造函数

class   base{

base(){

System out println( base   constructor )

}

}

class   derived   extends   base{

derived(){

System out println( derived   constructor )

}

public   static   void   main(String[]   args){

derived   d=new   derived()

}

}

执行结果如下 说明了先产生base   class然后是derived   class

base   constructor

derived   constructor

我要说明的问题出在如果base   class有多个constructor

而derived   class也有多个constructor 这时子类中的构造函数缺省调用那个父类的构造函数呢?答案是调用父类的缺省构造函数 但是不是编译器自动为你生成的那个缺省构造函数而是你自己显式地写出来的缺省构造函数

class   base{

base(){

System out println( base   constructor )

}

base(int   i){

System out println( base   constructor   int   i )

}

}

class   derived   extends   base{

derived(){

System out println( derived   constructor )

}

derived(int   i){

System out println( derived   constructor   int   i )

}

public   static   void   main(String[]   args){

derived   d=new   derived()

derived   t=new   derived( )

}

}

D: java thinking think >java   derived

base   constructor

derived   constructor

base   constructor

derived   constructor   int   i

如果将base   类的构造函数注释掉 则出错

class   base{

//   base(){

//   System out println( base   constructor )

//   }

base(int   i){

System out println( base   constructor   int   i )

}

}

class   derived   extends   base{

derived(){

System out println( derived   constructor )

}

derived(int   i){

System out println( derived   constructor   int   i )

}

public   static   void   main(String[]   args){

derived   d=new   derived()

derived   t=new   derived( )

}

}

D: java thinking think >javac   derived java

derived java: :   cannot   resolve   symbol

symbol   :   constructor   base   ()

location:   class   base

derived(){

^

derived java: :   cannot   resolve   symbol

symbol   :   constructor   base   ()

location:   class   base

derived(int   i){

   errors

说明子类中的构造函数找不到显式写出的父类中的缺省构造函数 所以出错

那么如果你不想子类的构造函数调用你显式写出的父类中的缺省构造函数怎么办呢?

如下例

class   base{

//   base(){

//   System out println( base   constructor )

//   }

base(int   i){

System out println( base   constructor   int   i )

}

}

class   derived   extends   base{

derived(){

super( )

System out println( derived   constructor )

}

derived(int   i){

super(i)

System out println( derived   constructor   int   i )

}

public   static   void   main(String[]   args){

derived   d=new   derived()

derived   t=new   derived( )

}

}

D: java thinking think >java   derived

base   constructor   int   i

derived   constructor

base   constructor   int   i

derived   constructor   int   i

super(i)表示父类的构造函数base(i)请大家注意一个是super(i)一个是super( ) 大家想想是为什么??

lishixinzhi/Article/program/Java/hx/201311/27071

java继承中对构造函数是不继承的,只是调用(隐式或显式)。

举例说明:

public class FatherClass {

public FatherClass() {

System.out.println(100)

}

public FatherClass(int age) {

System.out.println(age)

}

}

public class SonClass extends FatherClass{

public SonClass() {

}

public SonClass(int c) {

System.out.println(1234)

}

public static void main(String[] args) {

SonClass s = new SonClass(66)

}

}

编译后执行结果如下:

分析:SonClass s = new SonClass(66)

执行这句时,调用

public SonClass(int c) {

System.out.println(1234)//系统会自动先调用父类的无参构造函数(super())

}

在这个构造函数中,等价于

public SonClass(int c) {

super()//必须是第1行,否则不能编译

System.out.println(1234)

}

所以结果是100 1234

在创建子类的对象时,Java虚拟机首先执行父类的构造方法,然后再执行子类的构造方法。在多级继承的情况下,将从继承树的最上层的父类开始,依次执行各个类的构造方法,这可以保证子类对象从所有直接或间接父类中继承的实例变量都被正确地初始化。

3.如果子类构造函数是这样写的

public SonClass(int c) {

super(22)//必须是第1行,否则不能编译

//显式调用了super后,系统就不再调用无参的super()了

System.out.println(1234)

}

执行结果是 22

1234

总结1:构造函数不能继承,只是调用而已。

如果父类没有无参构造函数

创建子类时,不能编译,除非在构造函数代码体中第一行,必须是第一行显式调用父类有参构造函数

如下:

SonClass (){

super(777)//显示调用父类有参构造函数

System.out.println(66)

}

如果不显示调用父类有参构造函数,系统会默认调用父类无参构造函数super()

但是父类中没有无参构造函数,那它不是不能调用了。所以编译就无法通过了。

总结2:创建有参构造函数后,系统就不再有默认无参构造函数。

如果没有任何构造函数,系统会默认有一个无参构造函数。