Java8接口中引入default關(guān)鍵字的本質(zhì)原因詳析
接口的常規(guī)實現(xiàn)方式
熟悉java接口的同學(xué)都知道,接口被某些類實現(xiàn)后,一旦在接口中增加了新方法,那么實現(xiàn)該接口的所有類都要實現(xiàn)這個新增的方法(即使這個新增的接口對某些類沒有用處)。
定義一個接口
public interface IDemo {
void func1();
}
類CDemo1實現(xiàn)接口IDemo
public class CDemo1 implements IDemo{
@Override
public void func1() {
}
}
類CDemo2實現(xiàn)接口IDemo
public class CDemo2 implements IDemo{
@Override
public void func1() {
}
}
在IDemo中新增加方法func2()
public interface IDemo {
void func1();
void func2();
}
可以看到CDemo1和CDemo2中需要強制實現(xiàn)方法func2(),如下圖所示:

接口中的default
上面的實例導(dǎo)致了前面提出的那個問題,一旦在接口中增加了新方法,那么已經(jīng)實現(xiàn)了該接口的所有的類都要實現(xiàn)這個新增的方法!那么,如果是JDK中的某個核心接口需要變更,需要新增某些方法呢?這個工作量更是可想而知,我們來看一下java.util.Collection這個接口,它在jdk1.7中的方法包括:

而在JDk 1.8中 Collection接口中包括方法如下:

其中新增的接口,都用default來修飾(jdk1.7升級到j(luò)dk1.8后,接口的重要變化),源代碼如下:
default Stream<E> stream() {
?return StreamSupport.stream(spliterator(), false);
}
default Stream<E> parallelStream() {
? ? return StreamSupport.stream(spliterator(), true);
}
default Spliterator<E> spliterator() {
? ? return Spliterators.spliterator(this, 0);
}
default boolean removeIf(Predicate<? super E> filter) {
? ? Objects.requireNonNull(filter);
? ? boolean removed = false;
? ? final Iterator<E> each = iterator();
? ? while (each.hasNext()) {
? ? ? ? if (filter.test(each.next())) {
? ? ? ? ? ? each.remove();
? ? ? ? ? ? removed = true;
? ? ? ? }
? ? }
? ? return removed;
}我們不僅大吃一驚,這還是我們熟知的接口嗎?接口中的方法居然有了實現(xiàn)代碼!吃驚過后,我們來想想作者的意圖。還是上面的代碼,我們新增方法func3(),并完成簡單的實現(xiàn)
public interface IDemo {
void func1();
void func2();
default void func3(){
System.out.println("this is default func2");
}
}
然后查看類CDemo1,一切正常,沒有任何錯誤提示:

實例化CDemo1后,可以正常調(diào)用func3方法,代碼如下:
public static void main(String[] args) {
CDemo1 cd1=new CDemo1();
cd1.func3();
}
讀到這里發(fā)現(xiàn)接口中通過default關(guān)鍵字來進行接口實現(xiàn)的好處了吧,簡單四個字就是 “方便擴展” !通過這個技術(shù)可以做到在接口中新增加方法并且不會影響到已經(jīng)實現(xiàn)了該接口的所有的類!包括jdk1.8新引入的Lambda表達式也是基于這一知識點來實現(xiàn)的!
接口中的static
與此同時,從jdk1.8開始,接口中可以通過static關(guān)鍵字來修飾方法,同樣可以對方法進行實現(xiàn)
static void func4(){
System.out.println("this is static func4");
}
調(diào)用方法也非常的簡單,接口.static 方法,例如:
IDemo.func4();
大家可以這樣理解,接口中的static方法可以作為工具方法來提供給大家進行方便調(diào)用!
Default好處
原先接口的缺陷是,修改接口后,則需要修改全部實現(xiàn)該接口的類,所以引進的默認方法。他們的目的是為了解決接口的修改與現(xiàn)有的實現(xiàn)不兼容的問題。
總結(jié)
到此這篇關(guān)于Java8接口中引入default關(guān)鍵字本質(zhì)原因的文章就介紹到這了,更多相關(guān)Java8接口引入default關(guān)鍵字內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家
相關(guān)文章
Java生成N個不重復(fù)的隨機數(shù)的三種方法總結(jié)
這篇文章主要為大家詳細介紹了三種Java生成N個不重復(fù)的隨機數(shù)的方法,文中的示例代碼講解詳細,具有一定的參考價值,有需要的可以了解下2023-10-10
詳解Spring Boot微服務(wù)如何集成fescar解決分布式事務(wù)問題
這篇文章主要介紹了詳解Spring Boot微服務(wù)如何集成fescar解決分布式事務(wù)問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-01-01
基于Graphics2D drawImage圖片失真的解決方案
這篇文章主要介紹了基于Graphics2D drawImage圖片失真的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11
SpringCloud Alibaba 基本開發(fā)框架搭建過程
這篇文章主要介紹了SpringCloud Alibaba 基本開發(fā)框架搭建過程,開發(fā)工具選用的idea,本文通過圖文實例相結(jié)合給大家分享搭建全過程,需要的朋友可以參考下2021-06-06
Resilience4J通過yml設(shè)置circuitBreaker的方法
Resilience4j是一個輕量級、易于使用的容錯庫,其靈感來自Netflix Hystrix,但專為Java 8和函數(shù)式編程設(shè)計,這篇文章主要介紹了Resilience4J通過yml設(shè)置circuitBreaker的方法,需要的朋友可以參考下2022-10-10

