您好,登錄后才能下訂單哦!
怎么在Java8中歲接口的特性進行測試?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
默認方法
方法前加default關鍵字就可以提供默認實現,類實現接口時,可以繼承接口的默認方法,也可以覆蓋默認方法。
interface People { default void eat(String name) { System.out.println(name + " is eating."); } }
抽象類也可以提供方法的默認實現,一個類可以同時繼承一個抽象類和多個接口,如果抽象類和接口中存在相同的方法時會怎么樣呢?
一個抽象類和多個接口
如果類繼承了抽象類,采取類優先的原則,優先繼承抽象類的方法。我們在編寫類的時候會發現,必須先extends類再implements接口,否則工具會提示extends的錯誤。不論抽象類的方法有沒有提供默認實現,類都會繼承抽象類的方法,就算接口的方法提供了默認實現,也完全不關心。
接口A,B:
interface A { default void eat() { System.out.println("A"); } } interface B { default void eat() { System.out.println("B"); } }
抽象類C:
abstract class C { public void eat() { System.out.println("C"); } }
測試類Test:
public class Test extends C implements A, B { public static void main(String[] args) { Test test = new Java8Test(); test.eat(); } }
輸出結果:
C
程序輸出C說明Test類繼承了抽象類C的eat方法的實現。
當抽象類C不提供eat方法的默認實現并且Test類不提供eat方法的重寫時,編譯器是不會放過Test類的,明明繼承了C類,卻不提供抽象方法的實現。編譯器不會關心Test是否還實現了其他接口并且接口中有相同方法,一碼歸一碼。
那么如果是抽象類提供了默認實現,接口沒有提供呢?
我們讓抽象類C實現eat方法,接口A只提供一個接口,類Test不重寫eat方法。
接口A,B:
interface A { void eat(); } interface B { default void eat() { System.out.println("B"); } }
抽象類C:
abstract class C { public void eat() { System.out.println("C"); } }
測試類Test:
public class Test extends C implements A, B { public static void main(String[] args) { Test test = new Test(); test.eat(); } }
運行main方法,控制臺打印出抽象類中eat方法的輸出結果。
其實我們可以這么理解,編譯器總要一步一步的編譯,首先編譯到extends,檢查所有的抽象方法是否被重寫,有沒被重寫的方法就拋出編譯錯誤,否則就繼續編譯。當編譯到implements時,類Test已經是擁有抽象類C所有方法的實現了,即已經提供了接口A和B中相同方法的重寫。
以上總結就是抽象類和接口的方法沖突時以抽象類為準就是了。如果抽象類不在了,兩個接口方法沖突了,該聽誰的呢?
多個接口
接口A提供方法默認實現,接口B只提供方法。
接口A、B:
interface A { default void eat() { System.out.println("A"); } } interface B { default void eat() { System.out.println("B"); } }
測試類Test:
public class Test implements A, B { public static void main(String[] args) { Test test = new Test(); test.eat(); } }
此時編譯器提示,類Test從類型A和B中繼承了eat()的不相關默認值。也就是說,當兩個接口沖突時,編譯器無法判斷繼承A還是繼承B的方法實現。這時候,類Test就需要自己提供eat()方法的實現了。
靜態方法
接口中也可以提供靜態方法,使用static關鍵字。類不能繼承接口的靜態方法,所以也不存在覆蓋靜態方法。訪問靜態方法時通過接口訪問,即People.eat(“name”)。
interface People { static void eat(String name) { System.out.println(name + " is eating."); } }
可以測試一下,調用繼承了People接口的類實例的eat方法,工具提示不能通過類實例訪問靜態成員。或者試著重寫一個eat方法并加上@Override注解,工具提示“Method does not override method from its superclass”。
看完上述內容,你們掌握怎么在Java8中歲接口的特性進行測試的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。