Java中的构造函数继承

Python011

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

Q1.java中只要调用子类的无参构造函数就要调用父类无参数的构造函数!

Q2.也不一定。

e.g 如果你子类只调用无参构造方法(没有调用多个参数的构造方法),那么父类的无参构造方法则可有可无,因为系统会帮你生成。

你应该知道,如果子只类定义了一个带有参数的构造方法,那么系统就不会帮你生成无参构造方法。父类也是如此。

1,Java的函数调用是虚拟调用,对象名.方法名,调用的都是其真实类型的函数,就是说,对象实际上是一个dog,那么调用的就是dog的重写方法。父类构造器之所以被调用,是因为子类的构造器会调用父类的构造器,整个过程实际上是dog的构造。

2,这个和初始化顺序有关,new对象时,会先初始化成员变量再调用构造器,所以初始化顺序是:父类的成员变量->父类构造器->子类成员变量->子类构造器

也就是说,父类构造器中调用getAge的时候,dog的成员变量还没有初始化

等到子类构造器中再调用一次的时候,已经完成初始化。