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

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

相关文章

SpringBoot 自定义消息转换器使用详解

《SpringBoot自定义消息转换器使用详解》本文详细介绍了SpringBoot消息转换器的知识,并通过案例操作演示了如何进行自定义消息转换器的定制开发和使用,感兴趣的朋友一起看看吧... 目录一、前言二、SpringBoot 内容协商介绍2.1 什么是内容协商2.2 内容协商机制深入理解2.2.1 内容

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

模版方法模式template method

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/template-method 超类中定义了一个算法的框架, 允许子类在不修改结构的情况下重写算法的特定步骤。 上层接口有默认实现的方法和子类需要自己实现的方法

【iOS】MVC模式

MVC模式 MVC模式MVC模式demo MVC模式 MVC模式全称为model(模型)view(视图)controller(控制器),他分为三个不同的层分别负责不同的职责。 View:该层用于存放视图,该层中我们可以对页面及控件进行布局。Model:模型一般都拥有很好的可复用性,在该层中,我们可以统一管理一些数据。Controlller:该层充当一个CPU的功能,即该应用程序

迭代器模式iterator

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/iterator 不暴露集合底层表现形式 (列表、 栈和树等) 的情况下遍历集合中所有的元素

《x86汇编语言:从实模式到保护模式》视频来了

《x86汇编语言:从实模式到保护模式》视频来了 很多朋友留言,说我的专栏《x86汇编语言:从实模式到保护模式》写得很详细,还有的朋友希望我能写得更细,最好是覆盖全书的所有章节。 毕竟我不是作者,只有作者的解读才是最权威的。 当初我学习这本书的时候,只能靠自己摸索,网上搜不到什么好资源。 如果你正在学这本书或者汇编语言,那你有福气了。 本书作者李忠老师,以此书为蓝本,录制了全套视频。 试

Oracle type (自定义类型的使用)

oracle - type   type定义: oracle中自定义数据类型 oracle中有基本的数据类型,如number,varchar2,date,numeric,float....但有时候我们需要特殊的格式, 如将name定义为(firstname,lastname)的形式,我们想把这个作为一个表的一列看待,这时候就要我们自己定义一个数据类型 格式 :create or repla