java - 當在子類中聲明一個父類中存在的變量后,自動調用的父類構造函數不起作用。
問題描述
問題解答
回答1:執行順序是這樣的:
1. super();1.1. super.i = 7;1.2. this.setI(20) => this.i = 60;1.3. System.out.println('i from a is ' + super.i) => 7;2. this();2.1. this.i = 10;2.2. System.out.println('i from b is ' + this.i) => 10;
A.i 和 B.i 都是package-private的, B.i 沒有Override A.i, 這兩者是獨立的;
A.setI 和 B.setI 都是public, B.setI Override A.setI, A在構造時調用的是B.setI;
B在構造函數之外的成員初始化是在super()之后執行的, B.i先是在super里被B.setI設為60, 再被B的成員初始化設為10;
刪除B中的int i = 10;之后, 如果A和B處于同一個package, B.setI訪問的就是A.i, super()時A.i被設為60之后就不會有變更, 兩次打印都是60
回答2:在子類中再聲明一個父類中已有的成員,不會報錯嗎?至少也應該是警告吧。
我只能說,題目出得太缺德了。實際開發中不可能這么寫,自己給自己挖坑啊。
回答3:7.101.到A的構造方法,執行完Object的空參構造。2.int I=73.setI(20)調用的是子類的setI() 此時子類的I為60,父類的仍為7.4.打印this.i 此時在父類中.是 7;(注意點:變量看實際調用者, this是當前父類;方法因為被重寫,調用子類)5.int I=10 覆蓋了原先的60.6,打印this.i 此時為10.
60.60注意:你刪除了子類的I,默認調用的就是父類的I3.調用子類setI,賦值給了父類,此時父類改變為60.5.此時沒有覆蓋,this.i 默認調用父類繼承下來的I. 為60.
論Degbug的重要性...
