为什么要有无参构造方法,无参构造的运行原理
本文参考链接:https://blog.csdn.net/Akanarika520/article/details/84927403
无参构造器也叫无参构造方法,在我们创建类时候,可以不用写构造方法,因为系统会默认给我们提供一个无参构造方法,如果我们自己写了无参构造方法,那么我们这个就将默认的覆盖了。
(这时候你可能回想,既然会默认提供无参构造,我又为什么每次都要写无参构造呢?)
那么为什么一定要有这么一个无参构造方法呢?
1、因为我们在实例对象的时候,都要不断的向上(父类)回溯,回溯到Object(),要想顺利的回溯到Object,就必须给指定一条通路,如果没有,就用默认的 super()。
下面是我的一个测试,共有 GrandPa、Father和Son 3个类,
我现在在 main方法里 执行这条语句。Son son = new Son(); 控制台的输出结果如下:
由结果可知,一定不断的回溯到了Object,只不过是没有打印语句而已。若我们不指定调用父类的哪个构造方法。就会调用默认的无参构造方法,当然这个调用语句是在方法体的第一行。
如上上图所示,加不加 super()结果是一样的,因为默认有这一行。
(这时你可能会想为什么有时一定要加super,下面接着看)
2、那我把父类的无参构造方法去了还能回溯吗?当然可以,因为会默认有一个(没有输出语句的)。 把Father的无参构造方法注释掉,控制台输出如下:
我是爷爷的无参构造器
我是孩子的无参构造器
3、如果我的父类没有提供无参构造方法,但是提供了 有参构造方法,结果会如何?
子类直接出现编译错误,错误提示是: 在父亲类那里没有找到默认的构造器。 说明:如果父类没有提供默认的构造方法,而只是提供了有参构造方法,子类在继承时候,就会出错。
(解释什么时候一定要有super)
详细错误的原因解释是:编译器看到我们在Father类里写了有参构造法方法,它就会认为,我们不想让子类在回溯的时候走默认的无参构造方法这条路【super(); 此路不通】,但是我们又没告诉给子类,它应该走哪条路(你给了有参就是告诉我不要走无参,但也没告诉我走有参,那走哪?),所以会报错。 所以,若父类没有提供无参构造方法,但是提供了有参构造方法,就要在子类的无参构造方法里,显示的加上调用父类的有参构造方法语句。 如下:super(1);(这里就告诉了去走有参了)
控制台输出语句如下:
我是爷爷的无参构造器
我是父亲的有参构造器
我是孩子的无参构造器
证明,子类找到了回溯的路!
启示总结:
1.无参构造运行是需要往上一级一级找无参,甚至找到object
2.如果其中一级只有有参,没有无参,会发生错误。但只有无参,没有有参一定不会出错。
3.在以后的Java开发中,若一个POJO类要有带参构造方法,要记得先写无参构造方法。防止类追溯时找不到上级,报错。