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方法之前或者之后调用自己想要调用的方法,做自己想做的动作!

目录
相关文章
|
22天前
|
存储 负载均衡 监控
数据库多实例的深入解析
【10月更文挑战第24天】数据库多实例是一种重要的数据库架构方式,它为数据库的高效运行和灵活管理提供了多种优势。在实际应用中,需要根据具体的业务需求和技术环境,合理选择和配置多实例,以充分发挥其优势,提高数据库系统的性能和可靠性。随着技术的不断发展和进步,数据库多实例技术也将不断完善和创新,为数据库管理带来更多的可能性和便利。
92 57
|
27天前
|
XML 数据格式
HTML 实例解析
本文介绍了HTML中常见元素的使用方法,包括`<p>`、`<body>`和`<html>`等。详细解析了这些元素的结构和作用,并强调了正确使用结束标签的重要性。此外,还提到了空元素的使用及大小写标签的规范。
|
2月前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
415 37
|
1月前
|
移动开发 JavaScript 前端开发
Javaweb之Vue路由的详细解析
Vue.js是一款备受欢迎的前端框架,以其简洁的API和组件化开发模式著称。Vue Router作为其官方路由管理器,在构建单页面应用(SPA)时发挥关键作用,通过URL变化管理组件切换,实现无刷新过渡。本文将详细介绍Vue Router的基础概念、主要功能及使用步骤,帮助JavaWeb开发者快速掌握其工作原理及实践应用。
15 1
|
1月前
|
JSON JavaScript 前端开发
Javaweb中Vue指令的详细解析与应用
Vue指令提供了一种高效、声明式的编码方式,使得开发者可以更专注于数据和业务逻辑,而不是DOM操作的细节。通过熟练使用Vue指令,可以极大地提高开发效率和项目的可维护性。
20 3
|
2月前
|
数据可视化 Python
Python绘制基频曲线——实例解析与应用探讨
Python绘制基频曲线——实例解析与应用探讨
|
2月前
|
JavaScript 前端开发 UED
Javaweb中Vue指令的详细解析与应用
Vue指令是Vue框架中非常强大的特性之一,它提供了一种简洁、高效的方式来增强HTML元素和组件的功能。通过合理使用这些指令,可以使你的JavaWeb应用更加响应用户的操作,提高交互性和用户体验。而且,通过创建自定义指令,你可以进一步扩展Vue的功能,使其更贴合你的应用需求。
20 1
|
1月前
|
数据可视化 Python
Python绘制基频曲线——实例解析与应用探讨
Python绘制基频曲线——实例解析与应用探讨
|
7天前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
23 2
|
1月前
|
缓存 Java 程序员
Map - LinkedHashSet&Map源码解析
Map - LinkedHashSet&Map源码解析
67 0

推荐镜像

更多
下一篇
无影云桌面