使用Spring事件机制,合理的进行业务解耦
- 人工智能
- 2025-07-23 07:42:01

文章目录 事件机制介绍一、事件源类二、事件监听类1.方式一:自定义类实现 ApplicationListener 接口:1.方式二:通过注解去标记事件消费方法: 三、事件发布
事件机制介绍
事件发布流程中,有三个核心概念,他们之间的关系如下图:
事件源(ApplicationEvent):这个就是你要发布的事件对象。
事件发布器(ApplicationEventPublisher):这是事件的发布工具。
事件监听器(ApplicationListener):这个相当于是事件的消费者。
一、事件源类
这里我只是额外定义了一个 name 属性,如果大家在事件发送的时候需要传递的数据比较多,那么就可以在这里定义更多的属性(或者对象)。
public class MyEvent extends ApplicationEvent { private String name; public MyEvent(Object source, String name) { super(source); this.name = name; } @Override public String toString() { return "MyEvent{" + "name='" + name + '\'' + "} " + super.toString(); } }在具体实践中,事件源并非一定要继承自 ApplicationEvent,事件源也可以是一个普通的 Java 类,如果是普通的 Java 类,系统会自动将之封装为一个 PayloadApplicationEvent 对象去发送。
二、事件监听类 1.方式一:自定义类实现 ApplicationListener 接口: @Component public class MyEventListener implements ApplicationListener<MyEvent> { @Override public void onApplicationEvent(MyEvent event) { System.out.println("event = " + event); } } 1.方式二:通过注解去标记事件消费方法: @Component public class MyEventListener02 { @EventListener(value = MyEvent.class) public void hello(MyEvent event) { System.out.println("event02 = " + event); } } 三、事件发布 @Resource private ApplicationContext applicationContext; public void testEvent(){ applicationContext.publishEvent(new MyEvent(this, "javaboy")); }使用Spring事件机制,合理的进行业务解耦由讯客互联人工智能栏目发布,感谢您对讯客互联的认可,以及对我们原创作品以及文章的青睐,非常欢迎各位朋友分享到个人网站或者朋友圈,但转载请说明文章出处“使用Spring事件机制,合理的进行业务解耦”
上一篇
python实现B/B+树
下一篇
每日leetcode--接雨水