淺談java安全編碼指南之堆污染
產(chǎn)生堆污染的例子
有同學(xué)可能會(huì)問了,既然JDK5引入了泛型,為什么還會(huì)出現(xiàn)堆污染呢?
這是一個(gè)好問題,讓我們看一個(gè)例子:
public void heapPollution1(){
List normalList= Arrays.asList("www.flydean.com",100);
List<Integer> integerList= normalList;
}
上面的例子中,我們使用Arrays.asList創(chuàng)建了一個(gè)普通的List。
這個(gè)List中包含了int和String兩種類型,當(dāng)我們將List賦值給List
直接給List
我們看下下面的例子:
private void addToList(List list, Object object){
list.add(object);
}
@Test
public void heapPollution2(){
List<Integer> integerList=new ArrayList<>();
addToList(integerList,"www.flydean.com");
}
上面的例子中,我們定義了一個(gè)addToList方法,這個(gè)方法的參數(shù)是一個(gè)普通的List,但是我們傳入了一個(gè)List
結(jié)果,我們發(fā)現(xiàn)list.add方法并沒有進(jìn)行參數(shù)類型校驗(yàn)。
上面的例子該怎么修改呢?
我們需要在addToList方法的List參數(shù)中,也添加上類型校驗(yàn):
private void addToList(List<Integer> list, Object object){
list.add(object);
}
如果addToList是一個(gè)非常通用的方法怎么辦呢?在addToList的參數(shù)中添加參數(shù)類型是現(xiàn)實(shí)的。
這個(gè)時(shí)候,我們可以考慮使用Collections.checkedList方法來將輸入的List轉(zhuǎn)換成為一個(gè)checkedList,從而只接收特定類型的元素。
public void heapPollutionRight(){
List<Integer> integerList=new ArrayList<>();
List<Integer> checkedIntegerList= Collections.checkedList(integerList, Integer.class);
addToList(checkedIntegerList,"www.flydean.com");
}
運(yùn)行上面的代碼,我們將會(huì)得到下面的異常:
java.lang.ClassCastException: Attempt to insert class java.lang.String element into collection with element type class java.lang.Integer
更通用的例子
上面我們定義了一個(gè)addToList方法,因?yàn)闆]有做類型判斷,所以可能會(huì)出現(xiàn)堆污染的問題。
有沒有什么辦法既可以通用,又可以避免堆污染呢?
當(dāng)然有的,我們看下面的實(shí)現(xiàn):
private <T> void addToList2(List<T> list, T t) {
list.add(t);
}
public <T> void heapPollutionRight2(T element){
List<T> list = new ArrayList<>();
addToList2(list,element);
}
上面的例子中,我們?cè)赼ddToList方法中定義了一個(gè)參數(shù)類型T,通過這樣,我們保證了List中的元素類型的一致性。
可變參數(shù)
事實(shí)上,方法參數(shù)可以是可變的,我們考慮下面的例子:
private void addToList3(List<Integer>... listArray){
Object[] objectArray = listArray;
objectArray[0]= Arrays.asList("www.flydean.com");
for(List<Integer> integerList: listArray){
for(Integer element: integerList){
System.out.println(element);
}
}
}
上面的例子中我們的參數(shù)是一個(gè)List的數(shù)組,雖然List中的元素類型固定了,但是我們可以重新賦值給參數(shù)數(shù)組,從而實(shí)際上修改掉參數(shù)類型。
如果上面addToList3的方法參數(shù)修改為下面的方式,就不會(huì)出現(xiàn)問題了:
private void addToList4(List<List<Integer>> listArray){
這種情況下,List的類型是固定的,我們無法通過重新賦值的方式來修改它。
以上就是淺談java安全編碼指南之堆污染的詳細(xì)內(nèi)容,更多關(guān)于java安全編碼指南之堆污染的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Windows Zookeeper安裝過程及啟動(dòng)圖解
這篇文章主要介紹了Windows Zookeeper安裝過程及啟動(dòng)圖解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-12-12
詳解Java數(shù)據(jù)結(jié)構(gòu)之平衡二叉樹
平衡二叉樹(Balanced?Binary?Tree)又被稱為AVL樹(有別于AVL算法),且具有以下性質(zhì):它是一?棵空樹或它的左右兩個(gè)子樹的高度差的絕對(duì)值不超過1,并且左右兩個(gè)子樹都是一棵平衡二叉樹。本文將詳解介紹一下平衡二叉樹的原理與實(shí)現(xiàn),需要的可以參考一下2022-02-02
Java LocalCache 本地緩存的實(shí)現(xiàn)實(shí)例
本篇文章主要介紹了Java LocalCache 本地緩存的實(shí)現(xiàn)實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-05-05
解決Intellij IDEA 使用Spring-boot-devTools無效的問題
下面小編就為大家?guī)硪黄鉀QIntellij IDEA 使用Spring-boot-devTools無效的問題。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07
springboot增加注解緩存@Cacheable的實(shí)現(xiàn)
這篇文章主要介紹了springboot增加注解緩存@Cacheable的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12
使用ByteArrayOutputStream寫入字符串方式
這篇文章主要介紹了使用ByteArrayOutputStream寫入字符串方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12
MyBatis中mapper.java和mapper.xml的關(guān)系說明
這篇文章主要介紹了MyBatis中mapper.java和mapper.xml的關(guān)系說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05
Java ThreadLocal原理解析以及應(yīng)用場景分析案例詳解
這篇文章主要介紹了Java ThreadLocal原理解析以及應(yīng)用場景分析案例詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09

