JavaWeb-监听器Listener解析与实例

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: JavaWeb-监听器Listener解析与实例

首先来介绍一下什么是监听器:

监听器-就是一个实现待定接口的普通Java程序,此程序专门用于监听另外一个类的方法调用。

这是使用观察者模式的。

什么是观察者模式:

定义对象间一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知自动更新。  

示例:

GUI编程中的addXxxxListener都是观察者模式。

比如为按钮点击添加监听事件,为键盘添加监听等等…

观察者模式的三个重要类:

image.png

被监听的事件源,也就是我们在使用的对象。

注册的那个监听器,是专门用来监听当前使用的对象的。

事件对象Event也就是被监听的那个对象!

我们先来看一个简单版的,自己写的监听器。

简单版:

有事件源,和监听器,测试类.

Event等下一个完整版实现.

开发步骤:

第一步:实现一个需要被监听的类Person.

第二步:实现一个监听接口IPersonRunListener。

第三步:在Person类中,提供一个方法(或者多个,我在这里提供了2个方法)用于注册IPersonRunListener类,即addBefore和addAfter

第四步:必须要在Person类中维护IPersonRunListener类的实例。

第五步:在调用person.run方法时,判断IPersonRunListener是否为null,如果不为null则调用它的fighting方法。

第六步:在Demo类中,实例化Person,并注册一个监听。

Person:

package cn.hncu.designPattern1;
public class Person {
    private String name;
    private IPersonRunListener listener1;
    private IPersonRunListener listener2;
    public Person(String name) {
        super();
        this.name = name;
    }
    public void run(){
        if(listener1!=null){
            listener1.fighting();
        }
        System.out.println(name+"正在跑...");
        if(listener2!=null){
            listener2.fighting();
        }
    }
    public void addBefore(IPersonRunListener listener){
        this.listener1=listener;
    }
    public void addAfter(IPersonRunListener listener){
        this.listener2=listener;
    }
}
interface IPersonRunListener{
    public void fighting();
}

Demo

package cn.hncu.designPattern1;
public class Demo {
    public static void main(String[] args) {
        Person person = new Person("张三");
        IPersonRunListener listener = new IPersonRunListener() {
            @Override
            public void fighting() {
                //这里可以做很多事,不是只能输出哦
                //不过由于还没写Event对象,所以拿不到是谁调用的
                System.out.println("先做好准备工作...");
            }
        };
        person.addBefore(listener);
        A a = new A();
        person.addAfter(a);
        person.run();
    }
}
class A implements IPersonRunListener{
    @Override
    public void fighting() {
        //这里可以做很多事,不是只能输出哦
        //不过由于还没写Event对象,所以拿不到是谁调用的
        System.out.println("跑完了,休息休息...");
    } 
}

输出:

image.png

完整版–添加事件源:

在这里相对前面的增加了一个Event-事件对象.算是完整版的了。

开发步骤:

第一步:在前页的基础上继续添加一个PersonEvent类(注意我说是类不是接口),代表事件对像。

第二步:给PersonEvent对像,添加一个Person属性,用以标识事件源对像。

第三步:修改PersonListener接口的fighting方法,让它接收一个PersonEvent参数。

第四步:在Person类run方法中,如果判断PersonListener属性不为空,则在调用fighting方法,实例化PersonEvent并传给fighting方法。

第五步:在main方法中,通过PersonEvent的getSource方法测试是否是同一个对像。

Person.java

package cn.hncu.designPattern2;
public class Person {
    private String name;
    private IPersonRunListener listener;
    public Person(String name) {
        super();
        this.name = name;
    }
    public void run(){
        System.out.println(name+"开始跑了..");
        if(listener!=null){
            listener.fighting(new PersonEvent(this));
        }
    }
    public void addPersonListener(IPersonRunListener listener){
        this.listener=listener;
    }
    public String getName(){
        return name;
    }
    @Override
    public String toString() {
        return "Person [name=" + name + ", listener=" + listener + "]";
    }
}
interface IPersonRunListener {
    public void fighting(PersonEvent pe);
}
class PersonEvent{
    Person p = null;
    public PersonEvent(Person p) {
        this.p = p;
    }
    public String getName(){
        return p.getName();
    }
    public Object getSource(){
        return p;
    }
}
//我们还可以写一个帮我们实现了接口的基本类
//里面写我们通用的模板,如果我们继承这个类,我们就可以不写了。
//有功能不一样的地方,我们就自己写,覆盖这个类的方法
class DefaultCatListener implements IPersonRunListener {
    @Override
    public void fighting(PersonEvent pe) {
        System.out.println("默认的动作...");
    }
}

Demo.java

package cn.hncu.designPattern2;
public class Demo {
    public static void main(String[] args) {
        Person p1 = new Person("张三");
        Person p2 = new Person("Jack");
        IPersonRunListener listener = new IPersonRunListener() {
            @Override
            public void fighting(PersonEvent pe) {
                System.out.println(pe.getSource()+"已经跑完了...");
                if(pe.getName().equals("张三")){
                    System.out.println(pe.getName()+"跑到了第一名...");
                }
            }
        };
        p1.addPersonListener(listener);
        p2.addPersonListener(listener);
        p1.run();
        p2.run();
        Person p3 = new Person("李四");
        p3.addPersonListener(new DefaultCatListener());
        p3.run();
    }
}

演示结果:

image.png

基本上的原理就是这些了,里面事件的输出你换成你需要的动作就可以实现你想要的功能,添加一个监听,就可以在run方法之前或者之后调用自己想要调用的方法,做自己想做的动作!

目录
相关文章
|
2月前
|
存储 负载均衡 监控
数据库多实例的深入解析
【10月更文挑战第24天】数据库多实例是一种重要的数据库架构方式,它为数据库的高效运行和灵活管理提供了多种优势。在实际应用中,需要根据具体的业务需求和技术环境,合理选择和配置多实例,以充分发挥其优势,提高数据库系统的性能和可靠性。随着技术的不断发展和进步,数据库多实例技术也将不断完善和创新,为数据库管理带来更多的可能性和便利。
119 57
|
15天前
|
数据挖掘 vr&ar C++
让UE自动运行Python脚本:实现与实例解析
本文介绍如何配置Unreal Engine(UE)以自动运行Python脚本,提高开发效率。通过安装Python、配置UE环境及使用第三方插件,实现Python与UE的集成。结合蓝图和C++示例,展示自动化任务处理、关卡生成及数据分析等应用场景。
73 5
|
1月前
|
存储 网络协议 算法
【C语言】进制转换无难事:二进制、十进制、八进制与十六进制的全解析与实例
进制转换是计算机编程中常见的操作。在C语言中,了解如何在不同进制之间转换数据对于处理和显示数据非常重要。本文将详细介绍如何在二进制、十进制、八进制和十六进制之间进行转换。
39 5
|
2月前
|
存储 机器学习/深度学习 编解码
阿里云服务器计算型c8i实例解析:实例规格性能及使用场景和最新价格参考
计算型c8i实例作为阿里云服务器家族中的重要成员,以其卓越的计算性能、稳定的算力输出、强劲的I/O引擎以及芯片级的安全加固,广泛适用于机器学习推理、数据分析、批量计算、视频编码、游戏服务器前端、高性能科学和工程应用以及Web前端服务器等多种场景。本文将全面介绍阿里云服务器计算型c8i实例,从规格族特性、适用场景、详细规格指标、性能优势、实际应用案例,到最新的活动价格,以供大家参考。
|
2月前
|
SQL Java 数据库连接
canal-starter 监听解析 storeValue 不一样,同样的sql 一个在mybatis执行 一个在数据库操作,导致解析不出正确对象
canal-starter 监听解析 storeValue 不一样,同样的sql 一个在mybatis执行 一个在数据库操作,导致解析不出正确对象
|
3月前
|
XML 数据格式
HTML 实例解析
本文介绍了HTML中常见元素的使用方法,包括`<p>`、`<body>`和`<html>`等。详细解析了这些元素的结构和作用,并强调了正确使用结束标签的重要性。此外,还提到了空元素的使用及大小写标签的规范。
|
3月前
|
JavaScript API
深入解析JS中的visibilitychange事件:监听浏览器标签间切换的利器
深入解析JS中的visibilitychange事件:监听浏览器标签间切换的利器
175 0
|
3月前
|
数据可视化 Python
Python绘制基频曲线——实例解析与应用探讨
Python绘制基频曲线——实例解析与应用探讨
27 0
|
2月前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
87 2
|
10天前
|
存储 设计模式 算法
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析
行为型模式用于描述程序在运行时复杂的流程控制,即描述多个类或对象之间怎样相互协作共同完成单个对象都无法单独完成的任务,它涉及算法与对象间职责的分配。行为型模式分为类行为模式和对象行为模式,前者采用继承机制来在类间分派行为,后者采用组合或聚合在对象间分配行为。由于组合关系或聚合关系比继承关系耦合度低,满足“合成复用原则”,所以对象行为模式比类行为模式具有更大的灵活性。 行为型模式分为: • 模板方法模式 • 策略模式 • 命令模式 • 职责链模式 • 状态模式 • 观察者模式 • 中介者模式 • 迭代器模式 • 访问者模式 • 备忘录模式 • 解释器模式
【23种设计模式·全精解析 | 行为型模式篇】11种行为型模式的结构概述、案例实现、优缺点、扩展对比、使用场景、源码解析

推荐镜像

更多