創建類時指定了有參數構造函數后,系統默認不會創建無參數構造函數,需要自己手動創建。
創建子類的對象實例時,默認會先調用父類的無參數的構造函數(默認構造函數)。
若父類未定義無參數構造函數,則在編譯階段報錯。
若子類指定了父類的有參構造函數,則可以通過編譯和運行。
子類聲明super(id, city)顯示調用父類有參構造函數
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
package cn.lw.testpkg; /** * @author wanglei 2018年4月18日 */ class predessor { private int id; private string city; public predessor( int id, string city) { this .id = id; this .city = city; } @override public string tostring() { return "predessor [id=" + id + ", city=" + city + "]" ; } } class successor extends predessor { private string name; private string sex; public successor(string name, string sex, int id, string city) { super (id, city); this .name = name; this .sex = sex; } @override public string tostring() { return "successor [name=" + name + ", sex=" + sex + "]" ; } } public class callconstructortest { public static void main(string[] args) { successor s2 = new successor( "a" , "male" , 1 , "hz" ); system.out.println(s2); } } |
輸出
successor [name=a, sex=male]
父類未定義無參數構造函數,子類不聲明super(id, city)
1
2
3
4
|
public successor(string name, string sex) { this .name = name; this .sex = sex; } |
編譯報錯
implicit super constructor predessor() is undefined. must explicitly invoke another constructor
父類顯示定義無參數構造函數,方法調用的傳遞性
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
package cn.lw.testpkg; /** * @author wanglei 2018年4月18日 */ class predessor { private int id; private string city; public predessor() { system.out.println( "調用了 predessor 無參的構造函數" ); } public predessor( int id, string city) { this .id = id; this .city = city; } @override public string tostring() { return "predessor [id=" + id + ", city=" + city + "]" ; } } class successor extends predessor { private string name; private string sex; public successor() { system.out.println( "調用了 successor 無參的構造函數" ); } public successor(string name, string sex) { this .name = name; this .sex = sex; } @override public string tostring() { return "successor [name=" + name + ", sex=" + sex + "]" ; } } public class callconstructortest { public static void main(string[] args) { successor s = new successor(); system.out.println(s); system.out.println( "--------------" ); successor s2 = new successor( "a" , "male" ); system.out.println(s2); } } |
輸出
調用了 predessor 無參的構造函數
調用了 successor 無參的構造函數
successor [name=null, sex=null]
--------------
調用了 predessor 無參的構造函數
successor [name=a, sex=male]
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:https://segmentfault.com/a/1190000014449811