JDK10新特性之var泛型和多個接口實現方法
簡介
在JDK10的新特性:本地變量類型var中我們講到了為什么使用var和怎么使用var。
今天我們來深入的考慮一下var和泛型,多個接口實現的問題。
實現多個接口
在JDK的實現和我們日常的工作中,很多時候都需要實現多個接口,我們舉常用的兩個例子ArrayList和CopyOnWriteArrayList。先看下他們的定義:
public class ArrayList<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, java.io.Serializable public class CopyOnWriteArrayList<E> implements List<E>, RandomAccess, Cloneable, java.io.Serializable
我們可以看到ArrayList和CopyOnWriteArrayList都實現了List,RandomAccess,Cloneable,Serializable這四個接口。
如果我們有一個ArrayList creater,可以創(chuàng)建ArrayList或者CopyOnWriteArrayList中的一個,那么代碼應該怎么寫呢?
public Object createList(boolean flag){ if(flag){ return new ArrayList<>(); }else{ return new CopyOnWriteArrayList<>(); } }
因為返回的值可能是ArrayList也可能是CopyOnWriteArrayList,我們只能以Object來替代要返回的對象。
如果返回了Object就沒有了泛型帶來的優(yōu)勢,有沒有什么方法讓我們清楚的知道要返回的對象到底是什么類型的呢?
大家第一個想到的可能就是創(chuàng)建一個新的接口,繼承List, RandomAccess, Cloneable, java.io.Serializable,然后createList返回該新創(chuàng)建的接口即可。
public interface ListInterface<E> extends List<E>, RandomAccess, Cloneable, java.io.Serializable { }
然后把createList方法改寫:
public <E> ListInterface<E> createListWithInterface(boolean flag) { if(flag){ return (ListInterface<E>) new ArrayList<E>(); }else{ return (ListInterface<E>) new CopyOnWriteArrayList<E>(); } }
新的方法可以帶泛型,并且明確的表明了要返回的是一個ListInterface。
新生成的ListInterface在你自己的代碼中使用是沒有問題的,考慮一下,如果你的代碼被別人引用,或者作為一個公共庫來被別人使用,第三方可能根本就不知道你的新創(chuàng)建的ListInterface到底是做什么的。
我們能不能使用一種更加直觀的方法來創(chuàng)建List呢?答案當然是可以的,看下面的例子:
public <T extends List<E> & RandomAccess & Cloneable & java.io.Serializable, E> T createListWithInterfaceT(boolean flag){ if(flag){ return (T) new ArrayList<E>(); }else{ return (T) new CopyOnWriteArrayList<E>(); } }
上面的例子中,我們使用了泛型T同時繼承了4個接口。然后將創(chuàng)建的List轉換成T返回。
這樣我們即得到了ArrayList和CopyOnWriteArrayList的公共類型,也不需要創(chuàng)建新的接口。
使用多個接口
上面我們創(chuàng)建了一個實現多個接口的泛型T。那么如果要使用它該怎么做呢?
public <T extends List<E> & RandomAccess & Cloneable & java.io.Serializable, E> void useGenericityType(){ VarGenericity varGenericity=new VarGenericity(); T list=varGenericity.createListWithInterfaceT(true); }
為了在方法內部使用T,我們必須在方法定義上面再重新申明一次T的定義。
這么做雖然可以實現我們的功能,但是實在是太麻煩了。
使用var
這個時候就可以使用var變量來替代了,我們看下下面的例子:
public void useVarInGenericityType(){ VarGenericity varGenericity=new VarGenericity(); var list=varGenericity.createListWithInterfaceT(true); }
是不是很簡單,并且var list變量保留了四個接口的所有公共方法。
總結
本文介紹了泛型在多個接口實現中的具體例子,并使用var來精簡代碼。
本文的例子[ https://github.com/ddean2009/
learn-java-base-9-to-20](https://github.com/ddean2009/ ...
到此這篇關于JDK10新特性之var泛型和多個接口實現方法的文章就介紹到這了,更多相關JDK10 var泛型和多個接口內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
基于Springboot2.3訪問本地路徑下靜態(tài)資源的方法(解決報錯:Not allowed to load local
這篇文章主要介紹了基于Springboot2.3訪問本地路徑下靜態(tài)資源的方法(解決報錯:Not allowed to load local resource),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-08-08