@Component
public class TaskManager {
@AutoWired
ApplicationContext context;
@AutoWired
ThreadPoolTaskScheduler threadPoolTaskScheduler;
private static TaskManager instance;
public static TaskManager getInstance()
{
if (instance == null){
synchronized(TaskManager.class) {
if (instance == null) {
instance = new TaskManager();
}
}
}
return instance;
}
项目做了一个 从数据库中读取 对应定时轮训任务的配置, 项目启动时自动加载对应定时任务,
但改成单例后 执行时,直接出现 context为空 threadPoolTaskScheduler也为空。 项目启动直接空指针异常 导致的启动失败。
具体原因应该是 单例类 实例化 后对应的 类并没有在内存空间,所以引入不到。
解决方式两种,
一、 需要引入的对象 直接采用 工具类 或 调用单例类外部引入
//SpringContext 工具类
public class SpringContextUtils implements ApplicationContextAware {
public static ApplicationContext applicationContext;
@Override
public void setApplicationContext(ApplicationContext applicationContext)
throws BeansException {
SpringContextUtils.applicationContext = applicationContext;
}
public static <T> T getBean(Class<T> requiredType) {
return applicationContext.getBean(requiredType);
}
}
// 在TaskManage 中采用
SpringContextUtils.getBean()
二、采用@PostConstruct 方式引入
@Autowired
ApplicationContext context;
@Autowired
private ThreadPoolTaskScheduler threadPoolTaskScheduler;
public static TaskManager taskManager;
@PostConstruct
public void init() {
taskManager = this;
taskManager.context = this.context;
taskManager.threadPoolTaskScheduler = this.threadPoolTaskScheduler;
}
@PostConstruct 该标注为JAVA 注解
标注在非静态void方法, 然后在加载Servlet时 执行,然后在服务器只执行一次。
很久没看过java ee加载流程 和spring 加载流程了。有些东西不是很熟悉,下面在继续更新的话会更新对应的 基础流程 和对应注解机制。 这个BUG 在网上搜索了好久 context 注入失败 也没有对应好用的解决方案,所以 必须记录一下 加强印象