JavaWeb监听器Listener实例解析

所属分类: 软件编程 / java 阅读数: 40
收藏 0 赞 0 分享

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

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

什么是观察者模式:
定义对象间一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知自动更新。
示例:
GUI编程中的addXxxxListener都是观察者模式。
比如为按钮点击添加监听事件,为键盘添加监听等等…

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

被监听的事件源,也就是我们在使用的对象。
注册的那个监听器,是专门用来监听当前使用的对象的。
事件对象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("跑完了,休息休息...");
 } 
}

输出:

完整版–添加事件源:

在这里相对前面的增加了一个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();
 }
}

演示结果:

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

Java的面向对象编程基本概念学习笔记整理

这篇文章主要介绍了Java的面向对象编程基本概念学习笔记整理,包括类与方法以及多态等支持面向对象语言中的重要特点,需要的朋友可以参考下
收藏 0 赞 0 分享

Eclipse下编写java程序突然不会自动生成R.java文件和包的解决办法

这篇文章主要介绍了Eclipse下编写java程序突然不会自动生成R.java文件和包的解决办法 的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

基于Java实现杨辉三角 LeetCode Pascal's Triangle

这篇文章主要介绍了基于Java实现杨辉三角 LeetCode Pascal's Triangle的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Java中Spring获取bean方法小结

Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架,如何在程序中获取Spring配置的bean呢?下面通过本文给大家介绍Java中Spring获取bean方法小结,对spring获取bean方法相关知识感兴趣的朋友一起学习吧
收藏 0 赞 0 分享

如何计算Java对象占用了多少空间?

在Java中没有sizeof运算符,所以没办法知道一个对象到底占用了多大的空间,但是在分配对象的时候会有一些基本的规则,我们根据这些规则大致能判断出来对象大小,需要的朋友可以参考下
收藏 0 赞 0 分享

剖析Java中的事件处理与异常处理机制

这篇文章主要介绍了Java中的事件处理与异常处理机制,讲解Java是如何对事件或者异常作出响应以及定义异常的一些方法,需要的朋友可以参考下
收藏 0 赞 0 分享

详解Java的Struts2框架的结构及其数据转移方式

这篇文章主要介绍了详解Java的Struts2框架的结构及其数据转移方式,Struts框架是Java的SSH三大web开发框架之一,需要的朋友可以参考下
收藏 0 赞 0 分享

Java封装好的mail包发送电子邮件的类

本文给大家分享了2个java封装好的mail包发送电子邮件的类,并附上使用方法,小伙伴们可以根据自己的需求自由选择。
收藏 0 赞 0 分享

在Java的Struts中判断是否调用AJAX及用拦截器对其优化

这篇文章主要介绍了在Java的Struts中判断是否调用AJAX及用拦截器对其优化的方法,Struts框架是Java的SSH三大web开发框架之一,需要的朋友可以参考下
收藏 0 赞 0 分享

java多线程Future和Callable类示例分享

JAVA多线程实现方式主要有三种:继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程。其中前两种方式线程执行完后都没有返回值,只有最后一种是带返回值的。今天我们就来研究下Future和Callab
收藏 0 赞 0 分享
查看更多