Java中使用Timer要注意的一点

遇到错误

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,而不是原来的周期性执行。




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值