您好,登錄后才能下訂單哦!
這篇文章主要介紹了Java8的默認方法是什么的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Java8的默認方法是什么文章都會有所收獲,下面我們一起來看看吧。
默認方法是接口中用default修飾的方法,其中包含方法內容
比如下面這個:
public interface InterfaceDemo { // 普通方法,只定義,不實現 void oldFun(); // 默認方法,又定義,又實現 default void newFun(){ System.out.println("newFun"); } }
為了向后兼容(這也是導致Java變得臃腫的原因之一)。
因為升級系統時,難免會有一些新功能需要加入,此時如果接口類新增了方法,那么實現類就必須同步修改實現;
這樣工作量還是很大的,而且很容易出錯。
所以Java8開始,推出了接口的默認方法這個功能,使得接口升級變得更加平滑
比如下面的代碼:InterfaceDemo就是上面那個接口
public class UserDemo implements InterfaceDemo{ @Override public void oldFun() { System.out.println("oldFun"); } public static void main(String[] args) { UserDemo demo = new UserDemo(); /** * InterfaceDemo升級后,新增了newFun方法 * 但是由于newFun是默認方法,有提供實現內容 * 所以這里的子類 UserDemo就可以直接使用 */ demo.newFun(); } }
我們可以看到,UserDemo沒有實現新的方法newFun(),但是也可以編譯運行,并直接調用newFun()
這就是默認方法的好處:對實現類來說是無痛升級的
不提供的話,接口類升級時,系統有兩個選擇
實現類升級:
實現類老老實實地按照接口升級后的方法,進行同步修改實現,但是工作量大
實現類不升級:
實現類不升級也是可以的,只要不引入接口類的新版本就可以了,那么這個時候系統還是可以運行的,這沒啥問題。但是誰能保證一輩子都不更新系統呢?如果更新系統時,接口類庫升級到新版本,那么編譯還是通不過
接口的默認方法主要是針對類庫設計者
區別沒有之前那么多,但還是有的:
抽象類單繼承,接口類多實現
抽象類中的屬性定義時不需要初始化,接口類的屬性定義時要初始化(默認修飾符為public static final)
可以這么說。
但是現在面臨的一個新問題,就是多重繼承帶來的二義性問題,有點類似之前介紹的致命方塊(也叫菱形問題)
如下面的UML圖所示
比如上面這種,你無法知道A會調用哪個接口的fun方法
所以編譯器會報錯:
com.jalon.java8.defaultmethod.A inherits unrelated defaults for fun() from types com.jalon.java8.defaultmethod.B and com.jalon.java8.defaultmethod.C
解決辦法:
先覆寫fun方法
再顯示聲明調用哪個接口的fun方法
代碼如下:
public class A implements B,C{ @Override public void fun(){ // 顯示調用B的默認方法 B.super.fun(); } public static void main(String[] args) { A a = new A(); // 這里會打印B的fun a.fun(); } } interface D{ default void fun(){ System.out.println("D"); } } interface B extends D{ @Override default void fun(){ System.out.println("B"); } } interface C extends D{ @Override default void fun(){ System.out.println("C"); } }
關于“Java8的默認方法是什么”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Java8的默認方法是什么”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。