麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發 > Java > 正文

Java8中接口的新特性測試

2024-07-14 08:43:11
字體:
來源:轉載
供稿:網友

在Java SE 8之前,接口中是不能提供方法實現的,但是JDK8提供了接口的默認方法和靜態方法的支持。

默認方法

方法前加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”。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 亚洲国产网址 | 精品人伦一区二区三区蜜桃网站 | 91精品久久香蕉国产线看观看 | 亚洲午夜在线视频 | 成人精品 | 国产精品白嫩白嫩大学美女 | 国产一区二区三区四区精 | 末成年女av片一区二区 | 一日本道久久久精品国产 | 久久新地址 | 亚洲第一男人天堂 | 91精品国产91久久久 | 激情综合网俺也去 | 免费国产网站 | 一级@片| 午夜爽爽爽男女免费观看hd | 少妇的肉体k8经典 | 2019中文字幕在线播放 | 91婷婷射 | 国产艳妇av视国产精选av一区 | 午夜国产精品成人 | 欧美久久久一区二区三区 | 中国漂亮护士一级a毛片 | 98国内自拍在线视频 | 久久新地址 | 91精品国产91| 蜜桃91麻豆 | 羞羞视频免费观看入口 | 欧美视频一区二区三区四区 | 欧美成网站 | 国产精品1区2区 | 天堂成人一区二区三区 | 请播放一级毛片 | 中文字幕免费一区 | 精品国产亚洲人成在线 | 看一级毛片 | 欧美精品一区二区三区四区 | 欧美国产精品久久 | 双性精h调教灌尿打屁股的文案 | 国产精品亚洲一区二区三区久久 | 国产呦在线观看视频 |