web应用程序开发注意私自启动线程的问题
[b][color=blue]我们知道静态变量是ClassLoader级别的,如果Web应用程序停止掉,这些静态变量也会从JVM中清除.但是线程则是JVM级别的,如果用户在Web应用中启动一个线程,这个线程的生命周期并不会和Web应用程序操持同步.[/color]也就是,即使停止了Web应用,这个线程还是活跃的.正是因为这个很隐晦的问题,所以很多有经验的开发不太赞成在Web程序中私自启动线程.[/b]举例:
[code]public class Test implements ServletContextListener {
private Timer timer;
public void contextDestroyed(ServletContextEvent arg0) {
System.out.println("Web应用程序启动关闭...");
// timer.cancel();
}
public void contextInitialized(ServletContextEvent arg0) {
System.out.println("Web应用程序启动...");
timer = new Timer();
TimerTask task = new SimpleTimerTask();
timer.schedule(task, 1000L, 5000L);
}
}
class SimpleTimerTask extends TimerTask {
private int count;
public void run() {
System.out.println((++count)+"execute task..."+(new Date()));
}
}[/code]
有web.xml文件中配置:
[code] <listener>
<listener-class>
com.javaeye.lighter.Test
</listener-class>
</listener>[/code]
假如这一个时候登录Tomcat的后台,将对应的Web应用关闭.这时候,我们将在Tomcat的控制台看到web应用已经关闭了,但TImer任务还继续地执行.
[b][color=blue]我们知道静态变量是ClassLoader级别的,如果Web应用程序停止掉,这些静态变量也会从JVM中清除.但是线程则是JVM级别的,如果用户在Web应用中启动一个线程,这个线程的生命周期并不会和Web应用程序操持同步.[/color]也就是,即使停止了Web应用,这个线程还是活跃的.正是因为这个很隐晦的问题,所以很多有经验的开发不太赞成在Web程序中私自启动线程.[/b]举例:
[code]public class Test implements ServletContextListener {
private Timer timer;
public void contextDestroyed(ServletContextEvent arg0) {
System.out.println("Web应用程序启动关闭...");
// timer.cancel();
}
public void contextInitialized(ServletContextEvent arg0) {
System.out.println("Web应用程序启动...");
timer = new Timer();
TimerTask task = new SimpleTimerTask();
timer.schedule(task, 1000L, 5000L);
}
}
class SimpleTimerTask extends TimerTask {
private int count;
public void run() {
System.out.println((++count)+"execute task..."+(new Date()));
}
}[/code]
有web.xml文件中配置:
[code] <listener>
<listener-class>
com.javaeye.lighter.Test
</listener-class>
</listener>[/code]
假如这一个时候登录Tomcat的后台,将对应的Web应用关闭.这时候,我们将在Tomcat的控制台看到web应用已经关闭了,但TImer任务还继续地执行.