因?yàn)檎{(diào)試eclispe,斷修改初始內(nèi)存參數(shù),只設(shè)一個(gè)-Xmx是不夠的,還必須設(shè)置-Xms,開始懷疑初始化參數(shù)的作用。廢話不多說,開始研究。網(wǎng)上的好資料不多,有一篇解釋還比較清楚,就拿來主義了。
最近在網(wǎng)上看到一些人討論到j(luò)ava.lang.Runtime類中的freeMemory(), totalMemory(), maxMemory()這幾個(gè)方法的一些問題,很多人感到很疑惑,為什么,在java程序剛剛啟動(dòng)起來的時(shí)候freeMemory()這個(gè)方法返回的只有 一兩兆字節(jié),而隨著java程序往前運(yùn)行,創(chuàng)建了不少的對(duì)象,freeMemory()這個(gè)方法的返回有時(shí)候不但沒有減少,反而會(huì)增加。這些人對(duì) freeMemory()這個(gè)方法的意義應(yīng)該有一些誤解,他們認(rèn)為這個(gè)方法返回的是操作系統(tǒng)的剩余可用內(nèi)存,其實(shí)根本就不是這樣的。這三個(gè)方法反映的都是 java這個(gè)進(jìn)程的內(nèi)存情況,跟操作系統(tǒng)的內(nèi)存根本沒有關(guān)系。下面結(jié)合totalMemory(), maxMemory()一起來解釋。
maxMemory()這個(gè)方法返回的是java虛擬機(jī)(這個(gè)進(jìn)程)能構(gòu)從操作系統(tǒng)那里挖到的最大的內(nèi)存,以字節(jié)為單位,如果在運(yùn)行java程序的時(shí) 候,沒有添加-Xmx參數(shù),那么就是64兆,也就是說maxMemory()返回的大約是64*1024*1024字節(jié),這是java虛擬機(jī)默認(rèn)情況下能 從操作系統(tǒng)那里挖到的最大的內(nèi)存。如果添加了-Xmx參數(shù),將以這個(gè)參數(shù)后面的值為準(zhǔn),例如java -cp you_classpath -Xmx512m your_class,那么最大內(nèi)存就是512*1024*1024字節(jié)。
totalMemory()這個(gè)方法返回的是java虛擬機(jī)現(xiàn)在已經(jīng)從操作系統(tǒng)那里挖過來的內(nèi)存大小,也就是java虛擬機(jī)這個(gè)進(jìn)程當(dāng)時(shí)所占用的所有 內(nèi)存。如果在運(yùn)行java的時(shí)候沒有添加-Xms參數(shù),那么,在java程序運(yùn)行的過程的,內(nèi)存總是慢慢的從操作系統(tǒng)那里挖的,基本上是用多少挖多少,直 到挖到maxMemory()為止,所以totalMemory()是慢慢增大的。如果用了-Xms參數(shù),程序在啟動(dòng)的時(shí)候就會(huì)無條件的從操作系統(tǒng)中挖 -Xms后面定義的內(nèi)存數(shù),然后在這些內(nèi)存用的差不多的時(shí)候,再去挖。
freeMemory()是什么呢,剛才講到如果在運(yùn)行java的時(shí)候沒有添加-Xms參數(shù),那么,在java程序運(yùn)行的過程的,內(nèi)存總是慢慢的從操 作系統(tǒng)那里挖的,基本上是用多少挖多少,但是java虛擬機(jī)100%的情況下是會(huì)稍微多挖一點(diǎn)的,這些挖過來而又沒有用上的內(nèi)存,實(shí)際上就是 freeMemory(),所以freeMemory()的值一般情況下都是很小的,但是如果你在運(yùn)行java程序的時(shí)候使用了-Xms,這個(gè)時(shí)候因?yàn)槌?序在啟動(dòng)的時(shí)候就會(huì)無條件的從操作系統(tǒng)中挖-Xms后面定義的內(nèi)存數(shù),這個(gè)時(shí)候,挖過來的內(nèi)存可能大部分沒用上,所以這個(gè)時(shí)候freeMemory()可 能會(huì)有些大。
自己寫的一段小程序,用來幫助理解!java -cp . Getmem和java -cp . -Xms80m -Xmx80m Getmem比較!
Code
public class Getmem {
static int limit = 2000000;
public Getmem() {
}
public static void main(String args[]) {
getCurMem();
waitFor5s();
String tmpArray[] = new String[limit];
getCurMem();
waitFor5s();
for (int i = 0; i < limit; i++) {
tmpArray[i] = new String("abcde");
}
getCurMem();
waitFor5s();
}
static float bitTomega(long bit) {
return (float)bit/1024/1024;
}
static void getCurMem() {
SimpleDateFormat tmpDate = new SimpleDateFormat("yyyy-MM-dd" + " " + "hh:mm:ss");
System.out.println(tmpDate.format(new Date()));
System.out.println(" current memory: " + bitTomega(Runtime.getRuntime().totalMemory()) + "M");
System.out.println(" max memory: " + bitTomega(Runtime.getRuntime().maxMemory()) + "M");
System.out.println(" free memory: " + bitTomega(Runtime.getRuntime().freeMemory()) + "M");
}
static void waitFor5s() {
try {
Thread.sleep(5000);
} catch (Exception e) {
e.printStackTrace();
}
}
}
PS: xp系統(tǒng)自帶的任務(wù)管理器對(duì)于java的內(nèi)存反應(yīng)不是很靠譜,新版的還不錯(cuò),process explorer!
本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)
點(diǎn)擊舉報(bào)。