我遇到的問題是啟動定時器,然后在跟數據庫交互的地方報錯,Exception in thread "Timer-1" java.lang.NullPointerException。后來檢查了一下是因為,dataAcquisitionVoMapper沒有正常注入,原始代碼如下:
package com.hqgd.pms.controller.Timer; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.HashMap; import java.util.Map; import java.util.TimerTask; import javax.annotation.Resource; import com.hqgd.pms.common.SpringContextUtil; import com.hqgd.pms.dao.dataAcquisition.DataAcquisitionVoMapper; public class UpdateTableTimer extends TimerTask { @Resource private DataAcquisitionVoMapper dataAcquisitionVoMapper; // public UpdateTableTimer() {//從bean工廠里拿個實例 // this.dataAcquisitionVoMapper = SpringContextUtil.getBean(DataAcquisitionVoMapper.class); // } @Override public void run() { // 獲取當前時間 Calendar calendar = Calendar.getInstance(); calendar.add(Calendar.MINUTE, -1460); String lastTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(calendar.getTime()); Mapparam = new HashMap<>(); for (int i = 1; i <= 4; i++) { param.put("lastTime", lastTime); param.put("table", "hq_equipment_monitor_data_r" + i); dataAcquisitionVoMapper.deleter(param);//此處報空指針異常,是因為dataAcquisitionVoMapper沒有正常注入 } for (int i = 1; i <= 4; i++) { param.put("tabler", "hq_equipment_monitor_data_r" + i); param.put("tablef", "hq_equipment_monitor_data_f" + i); dataAcquisitionVoMapper.insertt(param); } } }
報錯提示如下:
在線程中為了線程安全,是防注入的,如果要用到這個類,只能從bean工廠里拿個實例。和上面的代碼對比,需要添加下面框框里的代碼,就是上面代碼注釋掉的部分,
SpringContextUtil工具類的代碼如下:
package com.hqgd.pms.common; import org.springframework.beans.BeansException; import org.springframework.context.ApplicationContext; import org.springframework.context.ApplicationContextAware; import org.springframework.stereotype.Component; /** * @Description: 獲取bean對象的工具類 * @Author: yaorong * @CreateDate: 2018/12/10 */ @Component public class SpringContextUtil implements ApplicationContextAware { /** * 上下文對象實例 */ private static ApplicationContext applicationContext; @Override public void setApplicationContext(ApplicationContext applicationContext) throws BeansException { SpringContextUtil.applicationContext = applicationContext; } /** * 獲取applicationContext * * @return */ public static ApplicationContext getApplicationContext() { return applicationContext; } /** * 通過name獲取 Bean. * * @param name * @return */ public static Object getBean(String name) { return getApplicationContext().getBean(name); } /** * 通過class獲取Bean. * * @param clazz * @param* @return */ public static T getBean(Class clazz) { return getApplicationContext().getBean(clazz); } /** * 通過name,以及Clazz返回指定的Bean * * @param name * @param clazz * @param * @return */ public static T getBean(String name, Class clazz) { return getApplicationContext().getBean(name, clazz); } }
好了,問題解決!!!
小小菜鳥,如有不正確之處,請指正!
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/74848.html
摘要:雖然本身支持定時任務,但都是服務一直運行時支持。監聽目標對象借助容器刷新事件來監聽目標對象即可,可以認為,定時任務其實每次只是執行一種操作而已。 在以往的 Tomcat 項目中,一直習慣用 Ant 打包,使用 build.xml 配置,通過 ant -buildfile 的方式在機器上執行定時任務。雖然 Spring 本身支持定時任務,但都是服務一直運行時支持。其實在項目中,大多數定時...
摘要:問題描述最近通知應用在近三個月內出現過次緩存的問題,第一次在重啟之后一直沒有出現過問題,所以也沒有去重視,但是最近又出現過一次,看來很有必要徹底排查一次具體的錯誤日志如下具體表現就是出現此異常之后連續的出現大量此異常 問題描述最近通知應用在近三個月內出現過2次DNS緩存的問題,第一次在重啟之后一直沒有出現過問題,所以也沒有去重視,但是最近又出現過一次,看來很有必要徹底排查一次;具體的錯...
摘要:在任務被拒絕添加后,會調用當前線程池的所在的線程去執行被拒絕的任務。會讓被線程池拒絕的任務直接拋棄,不會拋異常也不會執行。 開發技巧 equals() 方法的使用...
摘要:前言大家好,這里是從零開始學之數據類型,本文首發于公眾號,歡迎前往大家關注。輸出布爾類型中的布爾類型用表示,它的值有和。若需要可空引用時,布爾類型的值會被裝箱。此時程序會拋出異常最后從零開始學之數據類型到這里就結束了。 前言 大家好,這里是「從零開始學 Kotlin 之『2 』數據類型」,本文首發于公眾號「Binguner」,歡迎前往大家關注。我會每周分享一些關于 Android 和...
閱讀 2694·2023-04-25 17:58
閱讀 2978·2021-11-15 11:38
閱讀 2377·2021-11-02 14:48
閱讀 1184·2021-08-25 09:40
閱讀 1823·2019-08-30 15:53
閱讀 1093·2019-08-30 15:52
閱讀 1031·2019-08-30 13:55
閱讀 2435·2019-08-29 15:21