ThreadPoolTaskExecutor Run 执行报空指针

文艺骚年丶 2016-06-07 10:55:38
String tableName;
String areaCode;
QuartzController quartzController =new QuartzController();

public RunRuleInJVMDaemen(String tableName,String areaCode){
this.tableName = tableName;
this.areaCode = areaCode;
}

public synchronized void run() {
Map params = new HashMap<String,Object>();
params.put("tableName", tableName);
params.put("areaCode", areaCode);
quartzController.getTableBaseInfoS(params);
}

运行getTableBaseInfoS(); 方法 就报空指针
Exception in thread "ruleExecuterPool-1" java.lang.NullPointerException
求大神告知 怎么解决
...全文
839 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
文艺骚年丶 2016-06-07
  • 打赏
  • 举报
回复
引用 5 楼 qq_15915835 的回复:
你日志打在前面肯定有输出了,我猜你的controller里面的monitorService 是IOC 注入进来的吧。但是你在Quartz里面直接new的controller,monitorService肯定是空的啊。你可以拿到ApplicationContext ,从这里面那controller就可以了搜一下ApplicationContextAware 这个接口

一针见血啊 牛X大神,谢谢 我去试试
qq_15915835 2016-06-07
  • 打赏
  • 举报
回复
你日志打在前面肯定有输出了,我猜你的controller里面的monitorService 是IOC 注入进来的吧。但是你在Quartz里面直接new的controller,monitorService肯定是空的啊。你可以拿到ApplicationContext ,从这里面那controller就可以了搜一下ApplicationContextAware 这个接口
文艺骚年丶 2016-06-07
  • 打赏
  • 举报
回复
引用 3 楼 qq_15915835 的回复:
看一下这里 QuartzController.java:254

logger.info("TableBaseInfo 表名:"+param.get("tableName").toString()+" 地市:"+param.get("areaCode").toString());
List<Map<String, Object>> list = monitorService.getTableBaseInfo(param);

这里就是我去数据库查询我需要的数据,线程走到这里直接报空指针 不进方法了,但是我logger 已经打印出穿过来的数据了
qq_15915835 2016-06-07
  • 打赏
  • 举报
回复
看一下这里 QuartzController.java:254
文艺骚年丶 2016-06-07
  • 打赏
  • 举报
回复
引用 1 楼 qq_15915835 的回复:
异常栈都贴出来

2016-06-07 11:01:55 INFO [com.zb.web.controller.MoniJobController] 正在调度规则,地区:NJ,表名:RES_PHY_EQP_2_LOCATION
2016-06-07 11:01:55 INFO [com.zb.web.controller.MoniJobController] TableBaseInfo 表名:RES_PHY_EQP_2_LOCATION 地市:NJ
Exception in thread "ruleExecuterPool-1" java.lang.NullPointerException
at com.zb.web.controller.QuartzController.getTableBaseInfoS(QuartzController.java:254)
at com.zb.bean.service.impl.RunRuleInJVMDaemen.run(RunRuleInJVMDaemen.java:41)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:619)
这个就是全部的异常信息。。。。。
qq_15915835 2016-06-07
  • 打赏
  • 举报
回复
异常栈都贴出来

62,612

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧