class PrivateOverride { private void f() { System.out.println("private f()"); } public void hello(){ this.f(); this.bar(); } protected void bar(){ System.out.print("pri bar"); }}class Derived extends PrivateOverride { public void f() { System.out.println("public f()"); } public void bar(){ System.out.print("deri bar"); }}class Test4{ public static void main(String[] args) { Derived po = new Derived(); po.hello(); }}輸出: private f()deri bar為什么呢
5 回答

Qyouu
TA貢獻1786條經(jīng)驗 獲得超11個贊
首先這里并非直接調(diào)用
private
的f()
方法,就像getter
方法能拿到private
實例變量一樣,這個無需解釋。這里有個繼承的問題:
Derived
類里的f方法
并非是其父類PrivateOverride f方法
的重寫, 因為重寫方法要求重寫后方法的訪問權(quán)限修飾符不能比父類更嚴格,在hello
方法里執(zhí)行this.f()
,編譯器優(yōu)先找最近的f
(即父類的f
),所以打出了private f()
。
當然,在實際開發(fā)中,要盡量避免這種混淆,做做基礎(chǔ)面試題還可以。

繁星coding
TA貢獻1797條經(jīng)驗 獲得超4個贊
添加回答
舉報
0/150
提交
取消