java 释放数组_java集合ArrayList中clear方法内存释放分析
最近在看ArrayList源碼的時候看到了ArrayList的clear方法,源碼如下:
public void clear() {
modCount++;
// clear to let GC do its work
for (int i = 0; i < size; i++)
elementData[i] = null;
size = 0;
}
在看到這段代碼的時候聯(lián)想到內(nèi)存釋放的問題
如下代碼:
List listA = new ArrayList();
for(int i=0;i<100;i++){
listA.add(new String("arraylist"));
}
我創(chuàng)建了一個對象listA,并向listA中添加了100個元素,大家知道ArrayList的底層是數(shù)組,在創(chuàng)建listA之后,調(diào)用add方法之前,listA中存儲數(shù)據(jù)的數(shù)組(Object[] elementData)默認(rèn)是為空的elementData=null,在調(diào)用add方法之后才會初始化這個數(shù)組,并且默認(rèn)長度為10(元素個數(shù)超過數(shù)組長度之后會重新創(chuàng)建一個數(shù)組,并將原數(shù)據(jù)復(fù)制到新數(shù)組,數(shù)組擴展系數(shù)為原來的1.5倍)。那么在調(diào)用add方法添加元素之后listA內(nèi)存占用有如下兩個:
1、系統(tǒng)為listA中數(shù)組elementData分配的內(nèi)存;
2、向listA中添加元素占用的內(nèi)存;
在ArrayList中底層數(shù)組是Object類型,數(shù)組中存儲的并不是數(shù)據(jù)本身,而是數(shù)據(jù)的引用,那么現(xiàn)在在看clear的方法
public void clear() {
modCount++;
// clear to let GC do its work
for (int i = 0; i < size; i++)
elementData[i] = null;
size = 0;
}
方法中將數(shù)組元素清空設(shè)置為null,即清除了對所有元素的引用,那么系統(tǒng)在gc的時候會將所有的元素清除,釋放元素所占用的內(nèi)存空間。但是此時并沒有釋放系統(tǒng)分配給elementData數(shù)組的空間。
個人認(rèn)為這種方式?jīng)]有任何問題,因為通常我們在調(diào)用clear方法清空數(shù)據(jù)之后,往往還會向listA中重新添加數(shù)據(jù),如果在clear的時候?qū)lementData也設(shè)置為null,那么在重新添加數(shù)據(jù)的時候如果數(shù)據(jù)量很大,那么又會涉及到因為擴展數(shù)組長度復(fù)制數(shù)據(jù)而浪費時間。所以如果listA只用一次,那么可以在調(diào)用clear之后把listA也設(shè)置為null來釋放全部的內(nèi)存。要看具體場合用具體的功能。
listA.clear();
listA = null;
對list使用的個人建議
1、如果能大概知道有多少個元素,那么在創(chuàng)建list的時候可以直接指定長度,避免因擴展長度復(fù)制數(shù)據(jù)而浪費時間,List listA = new ArrayList(100000);
2、如果集合中存儲了大量的元素,并且集合已經(jīng)使用完畢,那么盡量調(diào)用clear方法來及時的釋放空間。如果集合不會重復(fù)使用,那么將集合也設(shè)置為null將內(nèi)存一并釋放。這樣有助于gc能更快完成清除內(nèi)存的工作。
實例:https://blog.csdn.net/china199225/article/details/52795771
總結(jié)
以上是生活随笔為你收集整理的java 释放数组_java集合ArrayList中clear方法内存释放分析的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ubuntu 破解mysql密码_Ubu
- 下一篇: ideajava目录显示类成员_面试:C