java事件机制(订阅/消费模型)/观察者模式 : EventObject,EventListener和Source

本文主要是介绍java事件机制(订阅/消费模型)/观察者模式 : EventObject,EventListener和Source,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考:

java事件机制(订阅/消费模型)

使用Java标准的java.util.EventListener实现观察者-发布者设计模式

java的事件机制一般包括三个部分:EventObjectEventListenerSource

简单示例demo:

1.EventObject : 事件

java.util.EventObject是事件状态对象的基类,它封装了事件源对象以及和事件相关的信息。
所有java的事件类都需要继承该类


import java.util.EventObject;public class MsgEvent extends EventObject {private static final long serialVersionUID = 1L;//也可以用source来传递值 这里用status来传递值private int status;public MsgEvent(Object source) {super(source);}public MsgEvent(Object source, int status) {super(source);this.status = status;}public int getStatus() {return status;}public void setStatus(int status) {this.status = status;}
}

2.EventListener : 监听事件

java.util.EventListener是一个标记接口,就是说该接口内是没有任何方法的。
所有事件监听器都需要实现该接口。
事件监听器注册在事件源上,当事件源的属性或状态改变的时候,调用相应监听器内的回调方法。

import java.util.EventListener;public interface MsgListener extends EventListener {void handleMsg(MsgEvent event) throws Exception;
}

3.Source

事件源不需要实现或继承任何接口或类,它是事件最初发生的地方。
因为事件源需要注册事件监听器,所以事件源内需要有相应的盛放事件监听器的容器。

触发动作 :


import java.util.ArrayList;
import java.util.List;public class MsgManager {static List<MsgListener> msgListeners = new ArrayList<MsgListener>();public static void addListener(MsgListener listener) {msgListeners.add(listener);}public static void sendMsg(MsgEvent event) throws Exception {notifyListeners(event);}public static void notifyListeners(MsgEvent event) throws Exception {for (MsgListener listener : msgListeners) {listener.handleMsg(event);}}public static void main(String[] args) {try {//监听器AMsgManager.addListener(new MsgListener() {public void handleMsg(MsgEvent event) throws Exception {System.out.println("MsgListenerA," + event.getStatus());}});//监听器BMsgManager.addListener(new MsgListener() {public void handleMsg(MsgEvent event) throws Exception {System.out.println("MsgListenerB," + event.getStatus());}});MsgEvent msg1 = new MsgEvent("test", 11);sendMsg(msg1);MsgEvent msg2 = new MsgEvent("test", 999);sendMsg(msg2);} catch (Exception e) {e.printStackTrace();}}
}

执行main 效果

MsgListenerA,11
MsgListenerB,11
MsgListenerA,999
MsgListenerB,999

demo2 : java.util.Observable + java.util.Observer 的使用

参考:从零开始理解JAVA事件处理机制(1)

观察者:


import java.util.Observable;
import java.util.Observer;/*** 观察者,学生*/
public class Student implements Observer {private String name;public Student(String name) {this.name = name;}@Overridepublic void update(Observable observable, Object arg) {Teacher teacher = (Teacher) observable;System.out.printf("学生%s观察到(实际是被通知)%s布置了作业《%s》 \n",this.name, teacher.getName(), arg);}}

被观察者


import java.util.ArrayList;
import java.util.List;
import java.util.Observable;/*** 被观察者,教师*/
public class Teacher extends Observable {private String name;private List<String> books;public String getName() {return this.name;}public Teacher(String name) {this.name = name;books = new ArrayList<String>();}public void setHomework(String homework) {System.out.printf("%s布置了作业%s \n", this.name, homework);books.add(homework);setChanged();notifyObservers(homework);}
}

客户端

public class Client {public static void main(String[] args) {Student student1 = new Student("张三");Student student2 = new Student("李四");Teacher teacher1 = new Teacher("王老师");teacher1.addObserver(student1);teacher1.addObserver(student2);teacher1.setHomework("事件机制第一天作业");}//王老师布置了作业事件机制第一天作业 //学生李四观察到(实际是被通知)王老师布置了作业《事件机制第一天作业》 //学生张三观察到(实际是被通知)王老师布置了作业《事件机制第一天作业》 
}

demo3 : 自定义Observable + Observer 的使用

参考:从零开始理解JAVA事件处理机制(1)

观察者:

public interface Observer {void update(Observable o);
}
class ConcreteObserver1 implements Observer {public void update(Observable o) {System.out.println("观察者1观察到" +o.getClass().getSimpleName() + "发生变化");System.out.println("观察者1做出响应");}
}
class ConcreteObserver2 implements Observer {public void update(Observable o) {System.out.println("观察者2观察到" +o.getClass().getSimpleName() + "发生变化");System.out.println("观察者2做出响应");}
}

被观察者:

import java.util.ArrayList;
import java.util.List;public class Observable {private List<Observer> observers = new ArrayList<Observer>();public void addObserver(Observer o) {observers.add(o);}public void doSomething() {System.out.println("我是被观察者,我发生变化了");// 主动去通知所有的观察者notifyObservers();}public void notifyObservers() {for (Observer observer : observers) {observer.update(this);}}
}

客户端:

public class Client {public static void main(String[] args) {Observable observable = new Observable();observable.addObserver(new ConcreteObserver1());observable.addObserver(new ConcreteObserver2());observable.doSomething();}//我是被观察者,我发生变化了//观察者1观察到Observable发生变化//观察者1做出响应//观察者2观察到Observable发生变化//观察者2做出响应
}

demo4 : EventListener + EventObject : 事件机制

参考:从零开始理解JAVA事件处理机制(2)

EventListener: 观察者接口(学生)

import java.util.EventListener;public interface HomeworkListener extends EventListener {void update(HomeworkEventObject eventObject, Object obj);
}
public class Student implements HomeworkListener {private final String name;public Student(String name) {this.name = name;}@Overridepublic void update(HomeworkEventObject eventObject, Object obj) {Teacher teacher = eventObject.getTeacher();System.out.printf("学生%s观察到(实际是被通知)%s布置了作业《%s》 \n",this.name, teacher.getName(), obj);}
}

EventObject:

java.util.EventObject是事件状态对象的基类,它封装了事件源对象以及和事件相关的信息。所有java的事件类都需要继承该类

import java.util.EventObject;public class HomeworkEventObject extends EventObject {public HomeworkEventObject(Teacher teacher) {super(teacher);}public Teacher getTeacher() {return (Teacher) super.getSource();}
}

被观察者:


import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;public class Teacher {private final String name;private final List<String> homeworks;/** 教师类要维护一个自己监听器(学生)的列表,为什么?* 在观察者模式中,教师是被观察者,* 继承自java.util.Observable,Observable中含了这个列表* 现在我们没有这个列表了,所以要自己创建一个*/private final Set<HomeworkListener> homeworkListenerList;public String getName() {return this.name;}public Teacher(String name) {this.name = name;this.homeworks = new ArrayList<String>();this.homeworkListenerList = new HashSet<HomeworkListener>();}public void setHomework(String homework) {System.out.printf("%s布置了作业%s\n", this.name, homework);homeworks.add(homework);HomeworkEventObject event = new HomeworkEventObject(this);/** 在观察者模式中,我们直接调用Observable的notifyObservers来通知被观察者* 现在我们只能自己通知了~~*/for (HomeworkListener listener : homeworkListenerList) {listener.update(event, homework);}}public void addObserver(HomeworkListener homeworkListener) {homeworkListenerList.add(homeworkListener);}}

测试:

public class Client {public static void main(String[] args) {Student student1 = new Student("张三");Student student2 = new Student("李四");Teacher teacher1 = new Teacher("杨振宁");teacher1.addObserver(student1);teacher1.addObserver(student2);teacher1.setHomework("事件机制第二天作业");}}

执行main打印:

杨振宁布置了作业事件机制第二天作业
学生张三观察到(实际是被通知)杨振宁布置了作业《事件机制第二天作业》 
学生李四观察到(实际是被通知)杨振宁布置了作业《事件机制第二天作业》 

这篇关于java事件机制(订阅/消费模型)/观察者模式 : EventObject,EventListener和Source的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/526578

相关文章

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

java中反射Reflection的4个作用详解

《java中反射Reflection的4个作用详解》反射Reflection是Java等编程语言中的一个重要特性,它允许程序在运行时进行自我检查和对内部成员(如字段、方法、类等)的操作,本文将详细介绍... 目录作用1、在运行时判断任意一个对象所属的类作用2、在运行时构造任意一个类的对象作用3、在运行时判断

java如何解压zip压缩包

《java如何解压zip压缩包》:本文主要介绍java如何解压zip压缩包问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解压zip压缩包实例代码结果如下总结java解压zip压缩包坐在旁边的小伙伴问我怎么用 java 将服务器上的压缩文件解压出来,

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Spring WebFlux 与 WebClient 使用指南及最佳实践

《SpringWebFlux与WebClient使用指南及最佳实践》WebClient是SpringWebFlux模块提供的非阻塞、响应式HTTP客户端,基于ProjectReactor实现,... 目录Spring WebFlux 与 WebClient 使用指南1. WebClient 概述2. 核心依

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.