jvm读取内存

本文介绍了一个简单的Java定时任务类GCTimerTask,用于监控JVM内存使用情况并触发垃圾回收。通过实例演示了如何使用Timer类及Runtime类的方法,并展示了在实际应用中遇到的内存溢出问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

packagecn.zhuangyan.util;

importjava.util.Timer;
importjava.util.TimerTask;
importjava.util.Calendar;
importjava.util.GregorianCalendar;
/**
*
*<p>Title:GCTimerTask</p>
*
*@authorzhuangyan
*@msn:nacl_zhuang@hotmail.com
*@qq:368924454
*@version1.0
*/
publicclassGCTimerTask
extendsTimerTask{

privatestaticGCTimerTaskinstance=null;
publicvoidrun(){
Calendarcal=newGregorianCalendar();
inthour24=cal.get(Calendar.HOUR_OF_DAY);//0..23
intmin=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();
}
privatevoidstartWork()
{
Timert=newTimer();
t.schedule(instance,0,1000*60);
}
publicstaticGCTimerTaskgetInstance()
{
if(instance==null)
{
instance=newGCTimerTask();
instance.startWork();
}
returninstance;
}
}


这个类虽然简单,但初学者从中应该学到
1)timer类的用法
2)java.lang.Runtime.getRuntime().freeMemory(),java.lang.Runtime.getRuntime().totalMemory(),System.gc()
这三个方法的使用,需要说明的是System.gc()并不能强迫JVM马上释放内存,如果那样,我的内存溢出问题早就解决了.
3)getInstance()单例模式,
4)最后的就是怎么用这个类的问题,我把它放到了EncodingFilter类中,现在很多jsp程序中都有这个类吧,
publicfinalvoidinit(finalFilterConfigarg0)throwsServletException{
GCTimerTask.getInstance();
this.filterConfig=arg0;
this.encoding=filterConfig.getInitParameter(\"encoding\");

Stringvalue=filterConfig.getInitParameter(\"ignore\");
if(value==null){

this.ignore=true;
}elseif(value.equalsIgnoreCase(\"true\")){

this.ignore=true;
}elseif(value.equalsIgnoreCase(\"yes\")){

this.ignore=true;
}else{

this.ignore=false;
}
}
=====================================
下面是溢出时日志,高手帮看一下.
[9:42]JVM可用内存:405M/508M
java.lang.OutOfMemoryError
[9:43]JVM可用内存:405M/508M
[9:44]JVM可用内存:405M/508M
[9:45]JVM可用内存:405M/508M
[9:46]JVM可用内存:405M/508M
[9:47]JVM可用内存:405M/508M
[9:48]JVM可用内存:404M/508M
[9:49]JVM可用内存:405M/508M
[9:50]JVM可用内存:404M/508M
[9:51]JVM可用内存:405M/508M
[9:52]JVM可用内存:405M/508M
[9:53]JVM可用内存:404M/508M
[9:54]JVM可用内存:405M/508M
[9:55]JVM可用内存:404M/508M
[9:56]JVM可用内存:405M/508M
[9:57]JVM可用内存:405M/508M
[9:58]JVM可用内存:405M/508M
[9:59]JVM可用内存:405M/508M
[10:0]JVM可用内存:405M/508M
[10:1]JVM可用内存:399M/508M
[10:2]JVM可用内存:404M/508M
[10:3]JVM可用内存:404M/508M
[10:4]JVM可用内存:404M/508M
[10:5]JVM可用内存:405M/508M
java.lang.OutOfMemoryError

为什么显示的可用内存有400多M,还OutOfMemoryError?在window的资源管理器中看tomcat的内存用量是持续增加的,它和java.lang.Runtime.getRuntime().freeMemory()是什么区别啊?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值