ddsspring中的事件机制使用到设计模式中的观察者模式 ,观察者模式有两个概念,1.观察者、被观察者。2.被观察者做出相应得动作,观察者能接收到。不分析设计模式,学习下spring中的事件机制实际开发如何使用 及使用场景 。

spring中的事件机制涉及到者几个类文件 :ApplicationEvent(事件类型)、ApplicationListener(事件监听类)、ApplicationEventPublisher(事件发布类)。先看看这几个类的继承、实现关系:

Application类继承jdk Utill包中的 EventObject,下面实现了很多子类:

ApplicationListener :接口继承了utill 包中的EventListener接口,泛型参数E必须继承ApplicationEvent类

ApplicationEventPublisher: 事件发布接口 ,实现类很多,其中子类ApplicationContext,发布事件就用ApplicationContext类去发布 

使用方法:

  1.声明事件类型

public class DemoEvent extends ApplicationEvent{
private static final long serialVersionUID = 1L; public DemoEvent(Object source) {
super(source);
} }

2.事件监听类

@Component  // 注意这里要把类注册到spring容器中
public class DemoListener implements ApplicationListener<DemoEvent> {//1
@Override
public void onApplicationEvent(DemoEvent event) {//2
Object o = event.getSource();
System.out.println("我(bean-demoListener)接收到了bean-demoPublisher发布的消息:"+ o); } }

3.配置类

@Configuration
@ComponentScan("springboot.springboot_learn.event") //扫描加载bean文件
public class EventConfig { }

4.事件发布 ,使用AnnotationConfigApplicationContext 类,这个为ApplicationContext的子类

public class Client {
public static void main(String[] args) throws InterruptedException {
AnnotationConfigApplicationContext context =
new AnnotationConfigApplicationContext(EventConfig.class); context.publishEvent(new DemoEvent("我要发财")); }
}

实际开发中使用场景 :提交一个订单order,成功后给用户发送短信,大多时候我们会写类似一下代码

public String submitOrder(OrderInfo orderinfo){
... // 省略代码
String rsMassage = dao.add(orderinfo);//插入信息
Boolean flag = sendSms(rsMassage); //发送短信
return flag ; //返回是否成功
}

这个代码一看是没有毛病。但是如果后续老板叫你,发送成功后还要给用户发个微信,还要给用户发个QQ...?,那么就要往submitOrder方法继续的添加代码,根据代码的开闭原则,这并不是最好的做法。那么可以做到,不修改代码,做到添加业务逻辑吗?利用spring的事件机制改造代码设计模式来实现。

1.申明事件类型

public class OrderEvent extends ApplicationEvent{
private static final long serialVersionUID = 1L; public OrderEvent(Object source) {
super(source);
} }

2.申明事件监听

@Component
class WeiChatListener implements ApplicationListener<OrderEvent>{ @Override
public void onApplicationEvent(OrderEvent event) {
System.out.println("微信发送短信:" + event.getSource());
} }

3.发布事件

 @Autowired
ApplicationContext applicationContext; //1
public String submitOrder(OrderInfo orderinfo){
... // 省略代码
String rsMassage = dao.add(orderinfo);//插入信息
applicationContext.publishEvent(new OrderEvent("我要发财"));
return "" ; //返回是否成功
}

后来老板叫你还要加个普通的短信?现在怎么办 ?修改代码吗 ?No 直接加个普通短信事件监听,注入实例到spring容器就ok了 ;

@Component
class massageListener implements ApplicationListener<OrderEvent>{ @Override
public void onApplicationEvent(OrderEvent event) {
System.out.println("发送不通短信:" + event.getSource());
} }

还要加别的xxx短信 ?? 。ok继续加个Listener,是不是这样优秀多了 0-0

观察者模式之spring事件机制的更多相关文章

  1. Spring事件机制详解

    一.前言 说来惭愧,对应Spring事件机制之前只知道实现 ApplicationListener 接口,就可以基于Spring自带的事件做一些事情(如ContextRefreshedEvent),但 ...

  2. 深入理解Spring事件机制(一):广播器与监听器的初始化

    前言 Spring 从 3.x 开始支持事件机制.在 Spring 的事件机制中,我们可以令一个事件类继承 ApplicationEvent 类,然后将实现了 ApplicationListener ...

  3. spring事件机制

    前置知识补充: 程序里面所谓的“上下文”就是程序的执行环境,打个比方:你就相当于web程序,你的房子就相当于web程序的上下文,你可以在家里放东西,也可以取东西,你的衣食住行都依赖这个房子,这个房子就 ...

  4. 搞清楚Spring事件机制后:Spring的源码看起来简单多了

    本文主讲Spring的事件机制,意图说清楚: 什么是观察者模式? 自己实现事件驱动编程,对标Spring的事件机制 彻底搞懂Spring中的事件机制,从而让大家 本文内容较长,代码干货较多,建议收藏后 ...

  5. 观察者模式模拟YUI事件机制

    首先介绍下YUI的事件机制,很好理解,因为和浏览器事件机制差不多.看懂下面几个方法就可以了: publish: 创建自定义事件.第一个参数是事件类型,第二个参数是一个对象,里面可以设置默认动作 on: ...

  6. Spring 事件机制

    通过模拟邮件的发送,说明Spring的事件监听机制 事件类 package org.zln.module_chapter2.event; import org.springframework.cont ...

  7. Spring 中的事件机制

    说到事件机制,可能脑海中最先浮现的就是日常使用的各种 listener,listener去监听事件源,如果被监听的事件有变化就会通知listener,从而针对变化做相应的动作.这些listener是怎 ...

  8. Spring 事件监听机制及原理分析

    简介 在JAVA体系中,有支持实现事件监听机制,在Spring 中也专门提供了一套事件机制的接口,方便我们实现.比如我们可以实现当用户注册后,给他发送一封邮件告诉他注册成功的一些信息,比如用户订阅的主 ...

  9. Spring的事件机制详解

    同步事件和异步事件 同步事件:在一个线程里,按顺序执行业务,做完一件事再去做下一件事. 异步事件:在一个线程里,做一个事的同事,可以另起一个新的线程执行另一件事,这样两件事可以同时执行. 用一个例子来 ...

随机推荐

  1. Visual Studio 2022 初探 (vs2022附激活码)

    前言 Visual Studio 2022 正式版来了.新版本带有 go-live 许可证,可供生产使用.在 Visual Studio 2019 的基础上,新版集成开发坏境提供了非常多的改进,包括对 ...

  2. K8S发布策略,无损发布

    大家好,相信大部分公司都已经使用K8S进行容器管理和编排了,但是关于K8S的发布策略,还有很多同学不太清楚,通过这篇文章的介绍,相信大家对目前K8S的发布情况有一个概括的认识.总结下来,共有如下几种: ...

  3. celery ValueError: invalid literal for int() with base 10: '26379;sentinel'

    celery使用redis sentinel作为broker的时候,因为redis sentinel配置字符串格式解析报错 ValueError: invalid literal for int() ...

  4. 通过实现仿照FeignClient框架原理的示例来看清FeignClient的本质

    前言 FeignClient的实现原理网上一搜一大把,此处我就不详细再说明,比如:Feign原理 (图解) - 疯狂创客圈 - 博客园 (cnblogs.com),而且关于FeignClient的使用 ...

  5. pycharm如何使用&python书写规范

    目录 1.pycharm如何使用 2.python 书写规范 1.pycharm如何使用 #主题的选择 file >> settings >> Editor >> ...

  6. JSON实现序列化dump和dumps方法,JSON实现反序列化loads和load方法

    通过文件操作,我们可以将字符串写入到一个本地文件.但是,如果是一个对象(例如列表.字典.元组等),就无 法直接写入到一个文件里,需要对这个对象进行序列化,然后才能写入到文件里. 设计一套协议,按照某种 ...

  7. Typora常用操作

    Typora常用操作 目录 Typora常用操作 1. 标题 2.子标题 3. 区块 4.代码 5. 表格 6. 超链接 7.单选框 8.数学公式 9.流程图 10.生成目录 11.字体设置 12. ...

  8. kali 安装typora

    一.安装 官网下载文件解压,并移动到 /opt 文件夹下 二.赋权 在typora目录的bin文件夹下执行命令 ./typora 会报错[7442:0707/173355.682906:FATAL:s ...

  9. [luogu6702]Path

    维护每一个点到根路径的异或和(记作$d_{k}$),根据异或自反性,$(x,y)$的异或和即$d_{x}\oplus d_{y}$ 考虑两条路径的lca,选择其中深度较大的点,另一条路径必然在其子树外 ...

  10. Ubuntu压缩和解压缩

    1.常用的压缩格式 tar tar.bz2 tar.gz 2.gzip压缩 gzip xxx //压缩 gzip -d xxx.gz //解压缩 gzip对文件夹的压缩 gzip -r xxx //文 ...