2010-10-22 16:38:54 org.apache.catalina.core.AprLifecycleListener init
信息: The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: D:\Program Files\Java\jdk1.6.0\jre\bin;D:\Program Files\Java\Tomcat 6.0\bin
2010-10-22 16:38:54 org.apache.coyote.http11.Http11Protocol init
信息: Initializing Coyote HTTP/1.1 on http-8080
2010-10-22 16:38:54 org.apache.catalina.startup.Catalina load
信息: Initialization processed in 1033 ms
2010-10-22 16:38:54 org.apache.catalina.core.StandardService start
信息: Starting service Catalina
2010-10-22 16:38:54 org.apache.catalina.core.StandardEngine start
信息: Starting Servlet Engine: Apache Tomcat/6.0.20
2010-10-22 16:38:55 org.apache.catalina.startup.HostConfig deployWAR
信息: Deploying web application archive NM_Web.war
2010-10-22 16:38:55 org.apache.catalina.core.StandardContext listenerStart
严重: Exception sending context initialized event to listener instance of class com.neusoft.listener.RunTimeListener
java.lang.NullPointerException
at com.neusoft.listener.RunTimeListener.contextInitialized(RunTimeListener.java:31)
at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3934)
at org.apache.catalina.core.StandardContext.start(StandardContext.java:4429)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:526)
at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:850)
at org.apache.catalina.startup.HostConfig.deployWARs(HostConfig.java:724)
at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:493)
at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1206)
at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:314)
at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:119)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
at org.apache.catalina.core.StandardHost.start(StandardHost.java:722)
at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
at org.apache.catalina.core.StandardService.start(StandardService.java:516)
at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
at org.apache.catalina.startup.Catalina.start(Catalina.java:583)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)
2010-10-22 16:38:55 org.apache.catalina.core.StandardContext start
严重: Error listenerStart
2010-10-22 16:38:55 org.apache.catalina.core.StandardContext start
严重: Context [/NM_Web] startup failed due to previous errors
2010-10-22 16:38:55 org.apache.catalina.core.ApplicationContext log
信息: timer is start
2010-10-22 16:38:55 org.apache.catalina.core.ApplicationContext log
信息: connect database
2010-10-22 16:38:56 org.apache.coyote.http11.Http11Protocol start
信息: Starting Coyote HTTP/1.1 on http-8080
2010-10-22 16:38:56 org.apache.jk.common.ChannelSocket init
信息: JK: ajp13 listening on /0.0.0.0:8009
2010-10-22 16:38:56 org.apache.jk.server.JkMain start
信息: Jk running ID=0 time=0/32  config=null
2010-10-22 16:38:56 org.apache.catalina.startup.Catalina start
信息: Server startup in 1631 ms源码:
RunTimeListener.java
---------------
public class RunTimeListener implements ServletContextListener {
private Timer timer = null; public void contextDestroyed(ServletContextEvent event) {
 timer = new Timer(true);
      event.getServletContext().log("timer is start");
      //timer.schedule(new exportHistoryBean(event.getServletContext()),0,5*1000);
      //timer.schedule(new exportHistoryBean(event.getServletContext()),0,5*1000);
     // timer.schedule(new Task(), new Date(),5*1000); 
  //timer.schedule(new Task2(), new Date(),8*1000);
  timer.schedule(new Task3(), new Date(),20*1000);
      event.getServletContext().log("connect database"); 
} public void contextInitialized(ServletContextEvent event) {
timer.cancel();
    event.getServletContext().log("timer is close");
}

}-----------RunTime .javapublic class RunTime { /**
 * @param args
 */
public static void main(String[] args) throws Exception{
// TODO Auto-generated method stub
Timer timer = new Timer(); 
timer.schedule(new Task3(), new Date(),20*1000);
System.out.println("#################");
}}------Task3。Java
public class Task3 extends TimerTask {
TestFileOutputStream getFile=new TestFileOutputStream();
DateFormat df2=new SimpleDateFormat("HH");
// DateFormat df=new SimpleDateFormat("mm:ss");
DateFormat df=new SimpleDateFormat("HH:mm");
String time=""; @Override
public void run() { 
Date date=new Date();
if("14:30".equals(df.format(date))){
String time2=df2.format(date);
if(!time2.equals(time)){
try{
getFile.getRecord();//调用录音文件读取方法
}catch(Exception e){
e.printStackTrace();
}
time=time2;
}
}


}}
------web.xml<listener>  
        <listener-class>com.neusoft.listener.RunTimeListener</listener-class>
    </listener>

解决方案 »

  1.   

    麻烦代码用 code的方式贴出来  看着很不舒服
      

  2.   

    java.lang.NullPointerException
    at com.neusoft.listener.RunTimeListener.contextInitialized(RunTimeListener.java:31)
    初步看是这个问题看下什么问题
      

  3.   

    public void contextInitialized(ServletContextEvent event) {
    timer.cancel();//这里显示为空,但没有理由啊
    event.getServletContext().log("timer is close");
    }
      

  4.   

    contextDestroyed 这个不是初始化,你把初始化和回收写反了吧?
      

  5.   

    public void contextInitialized(ServletContextEvent event) {
    timer.cancel();  这里报空指针
    }上来执行的是contextInitialized方法而不是contextDestroyed。
    所以你的timer上来是null,肯定要报空指针错误