您的位置:首页 > 编程语言 > Java开发

Java中使用Timer要注意的一点

2012-11-28 18:56 183 查看
遇到错误

java.lang.OutOfMemoryError:
unable to create new native thread


at java.lang.Thread.start0(Native Method)

at java.lang.Thread.start(Thread.java:597)

at java.util.Timer.<init>(Timer.java:154)

at java.util.Timer.<init>(Timer.java:122)

问题出在线程上,由于内存有限,无法再创建新的线程。

经过查找,得知可以修改java选项减少创建线程的消耗。

JAVA_OPTS=-Xms512M -Xmx1024M
-Xss128K

事实上问题仍未得到解决,-Xms512M -Xmx1024M并不是越大越好。

在程序中输出Thread信息,发现Timer的线程很多,也能观察到Timer线程会自动关闭。

当java进程消耗至280M时,tomcat就崩溃了。

仔细检查了一下程序中关于Timer的代码,

修改前是

Timer timer = new Timer(new MyTimerTask(),0,60000);

修改后

Timer timer = new Timer(new MyTimerTask(),10000);

并在MyTimerTask.Run中增加

finally{

Timer timer = new Timer(new MyTimerTask(),60000);

System.gc();//这一条很重要,否则还是会存在大量的timer线程

}

如上修改的原因是当一个task执行完后,再去执行新的task,而不是原来的周期性执行。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: