我明白了java 8接口中提供的默認方法可以減少應該在實現中編寫的代碼。天氣晴朗。但我不明白這一點,為什么將這個特性添加到語言中可以保護我們免受向后不兼容的影響?如果,比方說,我們已經將新方法添加到接口,那么我們可以簡單地在需要的( , 等)事件中List實現它,而沒有默認方法實現?ArrayListLinkedList確切的不兼容性隱藏在哪里?沒有默認方法可以破壞什么?這里的問題是關于破壞源兼容性,但我的問題有點另一個 - 關于保存它。
1 回答
慕萊塢森
TA貢獻1810條經驗 獲得超4個贊
如果,假設我們已經將新方法添加到接口 List,那么我們可以簡單地在需要的地方(ArrayList、LinkedList 等)事件實現它,而無需默認方法實現?
當您不控制 的所有實現時,您如何做到這一點List?你(指 Java 大神)可以將它添加到 JDK 中,但是其他人代碼中的所有實現如何?那些將不再編譯。如果有人試圖在他們的實現中調用其中一種新方法(從以前編譯的 JAR 文件中),他們會MethodNotFoundError在運行時遇到麻煩。
向后兼容性意味著現有代碼無需修改即可工作。在這種情況下,它們的目標是源代碼兼容性,這意味著您可以編譯相同的源代碼,而無需針對新的 Java 版本進行更改。另一件事是二進制兼容性,這意味著舊的編譯類繼續工作(Java 是著名的)。
源代碼兼容性不時被破壞(例如 JDBC API 因總是獲得新的接口方法而臭名昭著),但在這樣的中心類中卻沒有List(JDBC 更改僅影響數據庫驅動程序供應商,而不影響應用程序代碼) .
因此,如果沒有默認方法,就無法將新方法添加到List接口中。它需要是一個額外的EnhancedList或ListV8(所有 JDK 列表都已經實現,但所有使用的代碼都需要重構才能使用)。
添加回答
舉報
0/150
提交
取消
