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

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

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

其中新增的接口,都用default來(lái)修飾(jdk1.7升級(jí)到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;
}我們不僅大吃一驚,這還是我們熟知的接口嗎?接口中的方法居然有了實(shí)現(xiàn)代碼!吃驚過(guò)后,我們來(lái)想想作者的意圖。還是上面的代碼,我們新增方法func3(),并完成簡(jiǎn)單的實(shí)現(xiàn)
public interface IDemo {
void func1();
void func2();
default void func3(){
System.out.println("this is default func2");
}
}
然后查看類CDemo1,一切正常,沒(méi)有任何錯(cuò)誤提示:

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

