yuan_bin1990 2012-12-04 10:06 采纳率: 0%
浏览 789
已采纳

Timer定时器报错

今天使用Timer写定时程序,tomcat启动的时候出现以下异常信息:

 

严重: Error listenerStart
2012-12-4 9:57:28 org.apache.catalina.core.StandardContext start
严重: Context [/YGCWEB] startup failed due to previous errors
dddddd
2012-12-4 9:57:28 org.apache.catalina.loader.WebappClassLoader clearReferencesThreads
严重: The web application [/YGCWEB] appears to have started a thread named [Timer-2] but has failed to stop it. This is very likely to create a memory leak.

 

Web.xml部分配置如下:

 

  <listener>
  <listener-class>cn.system.util.listener.SessionListener</listener-class>
 </listener>
    <listener>
  <listener-class>cn.system.util.listener.ContextListener</listener-class>
 </listener> 

    <listener>
  <listener-class>cn.business.bakefile.ListenerTimerAutoBakeFile</listener-class>
 </listener>
  <listener>
  <listener-class>cn.system.task.MyListener</listener-class>
 </listener>

 

MyListener.java如下:

 

package cn.system.task;

import java.util.Timer;

import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;

public class MyListener implements ServletContextListener{

 private Timer myTaskTimer=null;
 @Override
 public void contextDestroyed(ServletContextEvent sce) {
  myTaskTimer=new Timer(true);
  myTaskTimer.schedule(new MyTask(),0,1000*60*60*24);
 }

 @Override
 public void contextInitialized(ServletContextEvent sce) {
  myTaskTimer.cancel();
 }

}

 

MyTask.java如下:

public class MyTask extends TimerTask{

 public void run() {
  System.out.println("dddddd");
 }

 

把web.xml的Listener去掉,启动tomcat可以正常访问,加上后就报严重信息,访问的时候报404

  • 写回答

1条回答 默认 最新

  • jinnianshilongnian 2012-12-04 10:11
    关注

    @Override
    public void contextDestroyed(ServletContextEvent sce) {
    myTaskTimer=new Timer(true);
    myTaskTimer.schedule(new MyTask(),0,1000*60*60*24);
    }

    @Override
    public void contextInitialized(ServletContextEvent sce) {
    myTaskTimer.cancel();
    }

    写反了

    contextInitialized 这是初始化 在这里创建
    contextDestroyed这是容器销毁 在这里cancel

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 sub地址DHCP问题
  • ¥15 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突
  • ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大