一個類對JVM可用記憶體進行了監測
- import java.util.Timer;
- import java.util.TimerTask;
- import java.util.Calendar;
- import java.util.GregorianCalendar;
- /**
- Title:GCTimerTask
- * @author zhuangyan
- * @msn:[email protected]
- * @qq:368924454
- * @version 1.0
- */
- public class GCTimerTask
- extends TimerTask {
- private static GCTimerTask instance = null;
- public void run() {
- Calendar cal = new GregorianCalendar();
- int hour24 = cal.get(Calendar.HOUR_OF_DAY); // 0..23
- int min = cal.get(Calendar.MINUTE); // 0..59
- System.out.print("["+String.valueOf(hour24)+":"+String.valueOf(min)+"]");
- System.out.println("JVM可用記憶體:" + java.lang.Runtime.getRuntime().
-
freeMemory() / (1024*1024)+"M/"+java.lang.Runtime.getRuntime()
.totalMemory()/(1024*1024)+"M" );
- System.gc();
- }
- private void startWork()
- {
- Timer t = new Timer();
- t.schedule(instance,0,1000*60);
- public static GCTimerTask getInstance()
- if(instance==null) {
- instance = new GCTimerTask();
- instance.startWork();
- return instance;
- }
這個類雖然簡單,但初學者從中應該學到
1)timer類的用法
2)java.lang.Runtime.getRuntime().freeMemory(),java.lang.Runtime.getRuntime().totalMemory(),System.gc()
這三個方法的使用,需要說明的是System.gc()并不能**JVM馬上釋放記憶體,如果那樣,我的記憶體溢出問題早就解決了.
3)getInstance()單例模式,
4)最後的就是怎麼用這個類的問題,我把它放到了EncodingFilter類中,現在很多JSP程式中都有這個類吧
- public final void init(final FilterConfig arg0) throws ServletException {
- GCTimerTask.getInstance();
- this.filterConfig = arg0;
- this.encoding = filterConfig.getInitParameter("encoding");
- String value = filterConfig.getInitParameter("ignore");
- if (value == null) {
- this.ignore = true;
- else if (value.equalsIgnoreCase("true")) {
- else if (value.equalsIgnoreCase("yes")) {
- else {
- this.ignore = false;
- }
JVM可用記憶體:405M/508M