解决:Implicit super constructor...
错误message:
// Implicit super constructor Super() is undefined. Must explicitly invoke another constructor
Given:
1. class Super {
2. private int a;
3. protected Super(int a) { this.a = a; }
4. }
...
11. class Sub extends Super {
12. public Sub(int a) { super(a); }
13. public Sub() { this.a = 5; }
14. }
Which two, independently, will allow Sub to compile? (Choose two.)
A. Change line 2 to:
public int a;
B. Change line 2 to:
protected int a;
C. Change line 13 to:
public Sub() { this(5); }
D. Change line 13 to:
public Sub() { super(5); }
E. Change line 13 to:
public Sub() { super(a); }
Answer: C,D
SCJP中其中一道题,其中主要考点:
- 对于继承中变量个继承访问关系
- 对于继承中构造方法的继承关系
分析:选项ABE 不正确原因,private int a; 父类私有变量会被子类继承,但是无法直接访问(使用),一般通过get(),set()来使用。
修改访问修饰符为public(选项A)和protected(选项B)虽然解决了考点1的问题(//The field Super.a is not visible),
但是考点2问题依然存在,所以错误。
选项CD 正确的原因,首先如果按照A/B将父类修改好后,在第13行public Sub() { this.a = 5; }会出现文章开头的编译错误。
造成这种错误的原因,要明确如下点:
1 如果在父类里定义了一个带参数的构造方法,那么这个父类就没有无参数的构造方法了。
2 子类在继承父类时,如果没有相同的带参构造方法,那么他就需要在其构造方法中明确的通过super()调用父类的带参构造方法(子类在自己的构造函数中必须显式的调用父类的构造函数),否则构造不出父类,从而也构造不出他自己了。
此时,选项D已经明确,通过super()调用了父类的带参构造方法,当然根据如上12点分析,如果在父类里追加protected Super(){},那么AB选项也正确(你如果在父类中写个不带参数的构造方法,就可以不用实现父类的带参构造方法了。)。
选项C正确的原因,需明确如下点:
this关键字:单纯表示"当前对象"(注意是针对对象而不是类的概念)
this方法 :通过使用this关键字带上参数,可以在一个构造函数中调用另外一个构造函数。
this明确注意点:
1 必须放在第一行。
2 只能调用一个其它的构造函数。(也许可以这样理解,正是因为有了第一点,如果可以调用多个的话,那么就无法放在"第一行",所以只能允许一次调用)。
3 只能是构造函数调用构造函数,普通函数无法调用构造函数。
4 构造方法会在成员变量之后初始化。
关于对象加载顺序可以参看另一篇博文: <<Java对象加载(初始化)顺序>>

222

被折叠的 条评论
为什么被折叠?



