Java项目启动时执行指定方法的几种方式
很多时候我们都会碰到需要在程序启动时去执行的方法,比如说去读取某个配置,预加载缓存,定时任务的初始化等。这里给出几种解决方案供大家参考。
1. 使用@PostConstruct注解
这个注解呢,可以在Spring加载这个类的时候执行一次。来看一下下方代码。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | @Component public class Test { public Test(){ System.out.println("我最先执行"); } /** *我第二个执行 */ @Autowired private T t; /** *我第三个个执行 */ @PostConstruct private void init(){ //假装有代码 } } |
上方就是@PostConstruct注解的使用方法了,同时也表示了此类被加载时的执行顺序。
2. CommandLineRunner接口
使用CommandLineRunner接口类似于Main方法启动,可以接受一个字符串数组的命令行参数,来看一下实现
1 2 3 4 5 6 7 8 | @Component public class MyCommandLineRunner implements CommandLineRunner{ @Override public void run(String... args) throws Exception{ //假装有代码 } } |
3. ApplicationRunner 接口
此种方式与实现CommandLineRunner接口的区别就是他的参数是ApplicationArguments
1 2 3 4 5 6 7 8 9 10 | @Order(value = 1) @Component public class MyApplicationRunner implements ApplicationRunner{ @Override public void run(ApplicationArguments args) throws Exception{ //假装有代码 } } |
我们可以看到,此类相比较于第二种方式还增加一个@Order注解,这个注解其实第二种方式也是能加的。
它的作用就是控制类的加载顺序,这个顺序是从小到大的。比如说启动时先去加载Order的value等于1的类,然后去加载等于2的类。
本文出自http://zhixiang.org.cn,转载请保留。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Java定时任务解决方案
版权声明:本文为博主原创文章,未经博主允许不得转载。博客源地址为zhixiang.org.cn https://blog.csdn.net/myFirstCN/article/details/81750829 很多项目中都会遇到需要定时任务的情况,本篇文章就结合了Spring中以及SpringBoot、SpringCloud中定时任务的解决方案。 在Spring中使用定时器 用SpringBoot比较多的同学可能都会觉得Spring的xml配置确实比较麻烦,如果想在Spring中使用定时器的话其实是必须使用xml配置文件的。 引入task约束 1 2 http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-3.0.xsd 开启注解 1 2 <task:scheduler id="Scheduler" pool-size="10"/> <task:annotation-driven scheduler="Scheduler" pro...
- 下一篇
使用Java类加载SpringBoot、SpringCloud配置文件
版权声明:本文为博主原创文章,未经博主允许不得转载。博客源地址为zhixiang.org.cn https://blog.csdn.net/myFirstCN/article/details/81750872 我们都知道平常在使用SpringBoot和SpringCloud的时候,如果需要加载一两个配置文件的话我们通常使用@Value("${属性名称}")注解去加载。但是如果配置文件属性特别多的时候使用这种方式就显得特别的不友好了。 比如说,我们要加载下方这个名为application.yml的配置文件。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 kafka: brokerAddress: 110.35.113.62:9092,123.27.143.72:9095,180.17.133.52:9096 smsTopic: testTopic smsCosumeGroup: testTopicGroup timerTaskTopic: timerTopic timerTaskGroup: timerGroup jvmNumber...
相关文章
文章评论
共有0条评论来说两句吧...