博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
springboot 中的commandLineRunners接口
阅读量:7189 次
发布时间:2019-06-29

本文共 2877 字,大约阅读时间需要 9 分钟。

首先看实现了两个接口运行的顺序结果:

My1:

package com.example.commandlinerunner; import lombok.extern.java.Log; import org.springframework.boot.CommandLineRunner; import org.springframework.core.annotation.Order; import org.springframework.core.annotation.OrderUtils; import org.springframework.stereotype.Component; import java.util.Arrays; /**  * Created by WangYx on 2017/9/14.  */ @Component @Order(6) @Log public class MyCmdLinerRunner1 implements CommandLineRunner {
@Override public void run(String... args) throws Exception {
log.info("MyCmdLinerRunner1:order = " + OrderUtils.getOrder(this.getClass())+" :args = " + Arrays.toString(args)); } private String getStacks(){
StringBuilder sb = new StringBuilder(); StackTraceElement[] elements = Thread.currentThread().getStackTrace(); sb.append("=============\n"); for (int i = 0 ; i < elements.length ; i++){
sb.append(elements[i]).append("\n"); } return sb.toString(); } } My2:
package com.example.commandlinerunner; import lombok.extern.java.Log; import org.springframework.boot.CommandLineRunner; import org.springframework.core.annotation.Order; import org.springframework.core.annotation.OrderUtils; import org.springframework.stereotype.Component; import java.util.Arrays; /**  * Created by WangYx on 2017/9/14.  */ @Component @Order(5) @Log public class MyCmdLinerRunner2 implements CommandLineRunner {
@Override public void run(String... args) throws Exception {
log.info("MyCmdLinerRunner2:order = " + OrderUtils.getOrder(this.getClass())+" :args = " + Arrays.toString(args)); } } 主函数:
package com.example.commandlinerunner; /**  * 通过CommandLineRunner,可在所有Spring Bean和 ApplicationContext被创建后执行一些可以访问命令行参数的任务。  * 如想指定多个CommandLineRunnerBean的执行顺序,  * 可以实现org.springframework.core.Ordered接口  * 或添加org.springframework.core.annotation.Order注解  */ import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class CommandlinerunnerApplication {
public static void main(String[] args) {
SpringApplication.run(CommandlinerunnerApplication.class, args); } } /** * org.springframework.core.annotation.AnnotationAwareOrderComparator负责对CommandLineRunnerBean进行排序。排序规则为: 如果有一方是org.springframework.core.PriorityOrdered接口实现,而另一方不是,则PriorityOrdered接口实现一方获胜; 检查org.springframework.core.Ordered接口或 org.springframework.core.annotation.Order 注解获得order,值小者胜; 其他没有order的则置为Ordered.LOWEST_PRECEDENCE,顺序不定。 在上述测试中,MyCmdLineRunner2的order为5,MyCmdLineRunner1的order为6,因此MyCmdLineRunner2在MyCmdLineRunner1之前执行。 Application的demo1和demo2方法设置了@order注解,但是调试可知lamda表达式生成类并没有@order注解信息,因此执行顺序排在后面。 这是需要注意的地方。此外,Bean初始化顺序跟CommandLineRunner执行顺序也没有关系。 */
 

转载于:https://www.cnblogs.com/wyx1202/p/7519976.html

你可能感兴趣的文章
内梯度—lhMorpGradientIn
查看>>
CherryPy:IOError: Port 8080 not free on '127.0.0.1'
查看>>
13.2 抽像类与体类(Abstract & Concrete Classes)
查看>>
对于结对编程的感悟
查看>>
Windows Phone开发(13):如何规范用户的输入行为
查看>>
两个长度分析【POST|GET】
查看>>
【Visual C++】游戏开发笔记之八——基础动画显示(二)游戏循环的使用
查看>>
C++生成随机数:连续均匀分布(uniform distribution)
查看>>
SQL函数--- SQL MAX()
查看>>
字体大宝库:25款精美的常用英文字体下载
查看>>
解决 Gtk-WARNING **: 无法在模块路径中找到主题引擎 pixmap
查看>>
HDU 1733 Escape
查看>>
Windows Phone卡通益智类游戏“狼来啦”
查看>>
记录我对枚举的初识
查看>>
spring aop实现权限控制,路径控制
查看>>
面试经验:Facebook面试问题总结
查看>>
[铁道部信息化管理]12306的已知信息、数据及问题
查看>>
display属性
查看>>
析构函数
查看>>
JavaScript:关于"超长原型链"的解释
查看>>