今天在项目中用到了@PostConstruct这个注解,顺便整理一下这个注解的用法。
该注解说明
@PostConstruct该注解被用来修饰一个非静态的void()方法。被@PostConstruct修饰的方法会在服务器加载Servlet的时候运行,并且只会被服务器执行一次。PostConstruct在构造函数之后执行,init()方法之前执行。
通常我们会是在Spring框架中使用到@PostConstruct注解 该注解的方法在整个Bean初始化中的执行顺序:
执行顺序(先---->后):Constructor(构造方法) -> @Autowired(依赖注入) -> @PostConstruct(注释的方法)
代码实战
package com.bos.quarz;
import com.aliyuncs.dysmsapi.model.v20170525.QuerySendDetailsResponse;
import com.aliyuncs.dysmsapi.model.v20170525.SendSmsResponse;
import com.bos.data.model.TemplateNewsModel;
import com.bos.service.AliYunMessageService;
import com.bos.service.WeiService;
import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import javax.annotation.PostConstruct;
import java.util.*;
/**
* 任务调度的执行类
*
* @Author tanghh
* @Date 2020/1/7 16:38
*/
@Component
public class QuartzTask implements Job {
private Logger logger = LoggerFactory.getLogger(QuartzTask.class);
@Autowired
private WeiService weiService;
@Autowired
private static QuartzTask quartzTask;
/**
* 通过@PostConstruct实现初始化bean之前进行的操作
*/
@PostConstruct
public void init() {
quartzTask = this;
quartzTask.weiService = this.weiService;
}
@Override
public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException {
System.out.println("quartz任务执行了...." + new Date());
try {
//获取传入的参数数据
System.out.println("weiService----"+weiService);
System.out.println("quartzTask.weiService----"+quartzTask.weiService);
} catch (Exception e) {
logger.error("提醒功能发生异常");
}
}
}
讲解部分
1.在上图中我在使用Quarz任务调度类, 我将weiService的实例方法放到了 @PostConstruct 中,
并且通过当前这个类去调用这个weiService ,然后再调用其他的业务逻辑代码,之所以这么写是因为光靠@Autowired 无法将service注入进来,运行报Null ,出现这种情况的时候就可以用@PointConstruct这个注解
以上就是我这次随笔内容,有不同意见的欢迎提出。