無論是在netBeans還是在eclipse開發環境中,寫java代碼的時候經常會碰到@Override,那麼@Override具體是什麼呢?
@Override是僞代碼,表示重寫(當然不寫也可以),不過寫上有如下好處:
1、可以當註釋用,方便閱讀
2、編譯器可以給你驗證@Override下面的方法名是否是你父類中所有的,如果沒有則報錯
比如你如果沒寫@Override而你下面的方法名又寫錯了,這時你的編譯器是可以通過的(它以爲這個方法是你的子類中自己增加的方法)。
如下例所示:
class Fu { private int a = 1; void print() { System.out.println("父類"); } } class Zi extends Fu { @Override void prin()//子類方法名與父類不同,編譯會出錯 { System.out.println("子類"); } } public class Test { public static void main(String[] args) { new Zi().prin(); } }
因此,在我們手工複寫父類的方法時,容易把方法的參數記錯或方法名寫錯,如果此時不加@Override的話,編輯器就不會提示。
以下引自:
分享一下@Override標籤背後的小祕密---記錄java的思行合一
《Thinking in java》的作者Bruce在討論這個問題的時候,提到了一個問題就是override私有的方法的例子:
現在我們向Fu類中添加一個私有方法,而在Zi中嘗試複寫
結果編譯器會提示錯誤,這是一個非常低級的錯誤,但是有時候恰恰就不會被我們發現:那就是試着複寫私有方法,但是當我們去掉Override標籤的時候,編譯器是不會報錯的,而且可以執行。
其實Zi中的你所謂複寫的print只是一個針對於Zi本身的私有方法。完全是一個新的方法。
這就引出了一個問題,何爲複寫?
在面向對象中,只有接口和共有方法,繼承方法纔有複寫,私有方法不可以複寫,但是又想了一下,才明白:不是不可以複寫,而是根本就不存在複寫私有方法的概念!
這正是面向對象設計的初衷,私有方法本身就是爲了封裝在類內部,不希望別人來更改或者外部引用的,看到這裏,忽然覺得,java設計的還真是不錯,感覺到了思想和實現的統一。
以前總覺得override標籤可有可無,但沒想到會引出這麼多的問題,於是乎得到一個啓示:認真思考每一個語法細節的意義,思行合一。