观察者模式(自定义监听器)

2024-06-08 00:58

本文主要是介绍观察者模式(自定义监听器),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概念:如果想对一个对象进行监听,那么这个对象内部就要具备监听的方法,没有的话就要自己自定义了。

	/*** 观察者模式的应用举例*/public static void main(String[] args) {// 创建对象Person person = new Person("张三");// 绑定监听器(自定义监听器就是在想要监听的类的内部存在一个监听器的方法)person.addPersonListener(new PersonListener() {//监听run方法的调用public void invokeRun(PersonEvent event) {//通过event来获得事件源Person person = event.getSource();System.out.println(person.getName() + "的 run 方法被调用了");}//监听eat方法的调用public void invokeEat(PersonEvent event) {Person person = event.getSource();System.out.println(person.getName() + "的 eat 方法被调用了");}});//由于绑定了监听器,所有只要一调用eat方法就会触发监听器中的处理器invokeEat方法的执行person.eat();}
}// 定义一个事件源(事件源存在监听器方法,这样才能对这个对象实行监视)
public class Person {//person中的属性以及set和get方法还有有参无参构造函数private String name;public String getName() {return name;}public void setName(String name) {this.name = name;}public Person() {super();}public Person(String name) {super();this.name = name;}private PersonListener listener;// 提供一个方法用于绑定监听器 注册监听器public void addPersonListener(PersonListener listener) {this.listener = listener;}//存在一个run方法public void run() {//实现事件的监听(形象说就是给这个方法添加了个铃铛,一触发就响铃,不添加这个铃就没法对他进行监视)//当调用到run方法的时候就会触发监听器的invokeRun抽象方法,就会覆盖事件源接口的方法this.listener.invokeRun(new PersonEvent() {public Person getSource() {// 当前内部类对象对应的外部类,如果这里返回的是this,则代表的是getSource这个方法//而Person.this就是返回的当前类的对象,正好是personreturn Person.this;}});System.out.println("run....");}//存在一个eat方法public void eat() {//实现事件的监听//当调用到eat方法的时候就会触发监听器的invokeEat抽象方法,就会覆盖事件源接口的方法this.listener.invokeEat(new PersonEvent() {public Person getSource() {// TODO Auto-generated method stubreturn Person.this;}});System.out.println("eat...");}
}public interface PersonListener {// 监听Person对象run方法被调用,由于这个方法我们不知道调用者要在方法中实现什么,所以就要设计成抽象方法,类就为接口//还需要将事件源传入,用于获得事件源中的属性void invokeRun(PersonEvent event);void invokeEat(PersonEvent event);
}// 事件
public interface PersonEvent {// 存在一个获得事件源Person的方法Person getSource();
}	


这篇关于观察者模式(自定义监听器)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Go语言实现桥接模式

《Go语言实现桥接模式》桥接模式是一种结构型设计模式,它将抽象部分与实现部分分离,使它们可以独立地变化,本文就来介绍一下了Go语言实现桥接模式,感兴趣的可以了解一下... 目录简介核心概念为什么使用桥接模式?应用场景案例分析步骤一:定义实现接口步骤二:创建具体实现类步骤三:定义抽象类步骤四:创建扩展抽象类步

kafka自定义分区器使用详解

《kafka自定义分区器使用详解》本文介绍了如何根据企业需求自定义Kafka分区器,只需实现Partitioner接口并重写partition()方法,示例中,包含cuihaida的数据发送到0号分区... 目录kafka自定义分区器假设现在有一个需求使用分区器的方法总结kafka自定义分区器根据企业需求

C++中的解释器模式实例详解

《C++中的解释器模式实例详解》这篇文章总结了C++标准库中的算法分类,还介绍了sort和stable_sort的区别,以及remove和erase的结合使用,结合实例代码给大家介绍的非常详细,感兴趣... 目录1、非修改序列算法1.1 find 和 find_if1.2 count 和 count_if1

Redis中群集三种模式的实现

《Redis中群集三种模式的实现》Redis群集有三种模式,分别是主从同步/复制、哨兵模式、Cluster,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1. Redis三种模式概述2、Redis 主从复制2.1 主从复制的作用2.2 主从复制流程2

深入理解MySQL流模式

《深入理解MySQL流模式》MySQL的Binlog流模式是一种实时读取二进制日志的技术,允许下游系统几乎无延迟地获取数据库变更事件,适用于需要极低延迟复制的场景,感兴趣的可以了解一下... 目录核心概念一句话总结1. 背景知识:什么是 Binlog?2. 传统方式 vs. 流模式传统文件方式 (非流式)流

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

SpringBoot AspectJ切面配合自定义注解实现权限校验的示例详解

《SpringBootAspectJ切面配合自定义注解实现权限校验的示例详解》本文章介绍了如何通过创建自定义的权限校验注解,配合AspectJ切面拦截注解实现权限校验,本文结合实例代码给大家介绍的非... 目录1. 创建权限校验注解2. 创建ASPectJ切面拦截注解校验权限3. 用法示例A. 参考文章本文

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

聊聊springboot中如何自定义消息转换器

《聊聊springboot中如何自定义消息转换器》SpringBoot通过HttpMessageConverter处理HTTP数据转换,支持多种媒体类型,接下来通过本文给大家介绍springboot中... 目录核心接口springboot默认提供的转换器如何自定义消息转换器Spring Boot 中的消息

C#和Unity中的中介者模式使用方式

《C#和Unity中的中介者模式使用方式》中介者模式通过中介者封装对象交互,降低耦合度,集中控制逻辑,适用于复杂系统组件交互场景,C#中可用事件、委托或MediatR实现,提升可维护性与灵活性... 目录C#中的中介者模式详解一、中介者模式的基本概念1. 定义2. 组成要素3. 模式结构二、中介者模式的特点