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

相关文章

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

浅析Java中如何优雅地处理null值

《浅析Java中如何优雅地处理null值》这篇文章主要为大家详细介绍了如何结合Lambda表达式和Optional,让Java更优雅地处理null值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录场景 1:不为 null 则执行场景 2:不为 null 则返回,为 null 则返回特定值或抛出异常场景

SpringMVC获取请求参数的方法

《SpringMVC获取请求参数的方法》:本文主要介绍SpringMVC获取请求参数的方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下... 目录1、通过ServletAPI获取2、通过控制器方法的形参获取请求参数3、@RequestParam4、@

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

SpringRetry重试机制之@Retryable注解与重试策略详解

《SpringRetry重试机制之@Retryable注解与重试策略详解》本文将详细介绍SpringRetry的重试机制,特别是@Retryable注解的使用及各种重试策略的配置,帮助开发者构建更加健... 目录引言一、SpringRetry基础知识二、启用SpringRetry三、@Retryable注解

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

通过Spring层面进行事务回滚的实现

《通过Spring层面进行事务回滚的实现》本文主要介绍了通过Spring层面进行事务回滚的实现,包括声明式事务和编程式事务,具有一定的参考价值,感兴趣的可以了解一下... 目录声明式事务回滚:1. 基础注解配置2. 指定回滚异常类型3. ​不回滚特殊场景编程式事务回滚:1. ​使用 TransactionT

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S