激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

香港云服务器
服務器之家 - 編程語言 - Java教程 - Java8中接口的新特性測試

Java8中接口的新特性測試

2021-06-21 13:47灰灰是菇涼呀 Java教程

今天小編就為大家分享一篇關于Java8中接口的新特性測試,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

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

默認方法

方法前加default關鍵字就可以提供默認實現,類實現接口時,可以繼承接口的默認方法,也可以覆蓋默認方法。

?
1
2
3
4
5
interface people {
  default void eat(string name) {
    system.out.println(name + " is eating.");
  }
}

抽象類也可以提供方法的默認實現,一個類可以同時繼承一個抽象類和多個接口,如果抽象類和接口中存在相同的方法時會怎么樣呢?

一個抽象類和多個接口

如果類繼承了抽象類,采取類優先的原則,優先繼承抽象類的方法。我們在編寫類的時候會發現,必須先extends類再implements接口,否則工具會提示extends的錯誤。不論抽象類的方法有沒有提供默認實現,類都會繼承抽象類的方法,就算接口的方法提供了默認實現,也完全不關心。

接口a,b:

?
1
2
3
4
5
6
7
8
9
10
interface a {
  default void eat() {
    system.out.println("a");
  }
}
interface b {
  default void eat() {
    system.out.println("b");
  }
}

抽象類c:

?
1
2
3
4
5
abstract class c {
  public void eat() {
    system.out.println("c");
  }
}

測試類test:

?
1
2
3
4
5
6
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:

?
1
2
3
4
5
6
7
8
interface a {
  void eat();
}
interface b {
  default void eat() {
    system.out.println("b");
  }
}

抽象類c:

?
1
2
3
4
5
abstract class c {
  public void eat() {
    system.out.println("c");
  }
}

測試類test:

?
1
2
3
4
5
6
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:

?
1
2
3
4
5
6
7
8
9
10
interface a {
   default void eat() {
     system.out.println("a");
   }
}
interface b {
  default void eat() {
     system.out.println("b");
   }
}

測試類test:

?
1
2
3
4
5
6
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”)。

?
1
2
3
4
5
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”。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對服務器之家的支持。如果你想了解更多相關內容請查看下面相關鏈接

原文鏈接:https://blog.csdn.net/sinat_28394909/article/details/84956125

延伸 · 閱讀

精彩推薦
1278
主站蜘蛛池模板: 国产成人羞羞视频在线 | 黄色免费在线网址 | av在线免费网 | v11av在线视频成人 | 欧美成人一区二区三区 | a视频在线看 | 九九热久久免费视频 | 欧美一级做性受免费大片免费 | 成人羞羞在线观看网站 | 在线看免费的a | av大全在线免费观看 | 久久精品电影网 | 一级毛片特黄 | 国产精品久久久久久久久久妇女 | 国产成人高清在线观看 | 国产69久久精品成人看 | 性生活视频一级 | 欧日韩| 黄在线免费看 | xxxxxx打针视频vk | 中国女警察一级毛片视频 | 毛片视频播放 | 亚洲第五色综合网 | 久久久久免费电影 | 久久免费视频3 | 香蕉成人在线观看 | 国产精品久久久久久久午夜片 | 黄色av免费网站 | 午夜小影院 | 国产午夜精品理论片a级探花 | 国产成人精品区一区二区不卡 | av电影在线观看免费 | 色网在线视频 | 玩偶姐姐 在线观看 | 天天看成人免费毛片视频 | 黄色毛片视频在线观看 | 欧美成人免费小视频 | 国产一级一国产一级毛片 | 亚洲一区成人在线观看 | 久久精品视频日本 | 成人免费av在线播放 |