java dispatchevent_java事件处理机制

java中的事件机制的参与者有3种角色:

1.event object:就是事件产生时具体的“事件”,用于listener的相应的方法之中,作为参数,一般存在与listerner的方法之中

2.event source:具体的接受事件的实体,比如说,你点击一个button,那么button就是event source,这样你必须使button对某些事件进行相应,你就需要注册特定的listener,比如说MouseEvent之中的MouseClicked方法,这是他就必须有了add方法

3.event listener:具体的对监听的事件类,当有其对应的event object产生的时候,它就调用相应的方法,进行处理。在windows程序设计里边这种相应使用callback机制来实现的

先看看jdk提供的event包:

public interface EventListener:所有事件侦听器接口必须扩展的标记接口。

public class EventObject extends Object implements Serializable所有事件状态对象都将从其派生的根类。 所有 Event 在构造时都引用了对象 "source",在逻辑上认为该对象是最初发生有关 Event 的对象。

在Java2处理事件时,没有采用dispatchEvent()-postEvent()-handleEvent()方式,采用了监听器类,每个事件类都有相关联的监听器接口。事件从事件源到监听者的传递是通过对目标监听者对象的Java方法调用进行的。      对每个明确的事件的发生,都相应地定义一个明确的Java方法。这些方法都集中定义在事件监听者(EventListener)接口中,这个接口要继承 java.util.EventListener。

实现了事件监听者接口中一些或全部方法的类就是事件监听者。      伴随着事件的发生,相应的状态通常都封装在事件状态对象中,该对象必须继承自java.util.EventObject。事件状态对象作为单参传递给应响应该事件的监听者方法中。发出某种特定事件的事件源的标识是:遵从规定的设计格式为事件监听者定义注册方法,并接受对指定事件监听者接口实例的引用。    开始之前首先问个问题:您熟悉java.util.EventObject 和java.util.EventListener两个类以及他们已有的子类吗?

如果你已经能够熟练使用jdk为我们提供的事件监听器,并且很熟悉MouseEvent, KeyEvent, WindowEvent等等这些jdk为我们准备好的事件,那么想必你对java的事件机制已经有所理解。但是也许你还是觉得虽然用起来没什么问题,但是原理还是有些糊涂,那么下面我们再进一步自己实现这些事件和监听器,我们把这个取名为自定义事件。   其实自定义事件在java中很有用处,我们有的时候想让自己的程序产生一个事件,但有不希望(或者不可能)用鼠标,键盘之类的输入设备进行操作,比如你写一个应用程序,在这个程序中一旦收到邮件就对邮件进行相关处理,对于“收到邮件”这个事件,jdk中就没有定义。对于这样的事件,以及对于这样的事件的监听器,我们只能自己动手完成了。

其实呢,java事件处理机制就是观察者模式,我这里详细的整理一下,在并发编程中,动不动就给某一个主题注册一个监听,然后当主题状态发生变化的时候,监听就会被触发。好了,废话不多说了,我贴出几篇代码好了。

第一步:

/**

*

*/

package test;

/**

* @author LinkinPark

* @date 2015年8月31日 下午3:07:34

* @Description:

* 前面我已经整理了观察者模式,这里对照这个设计模式来整理下java事件

* 这里先写个最简单的模拟

*/

public class Util

{

public static void main(String[] args)

{

// 首先初始化一个被观察者,然后在初始化一个观察者

// 然后将观察者绑定到被观察者上面,然后使用被观察者看看观察者里面的事件有没有被触发

Observable observable = new Observable();

Observer observer = new Observer();

observable.setObserver(observer);

observable.test();//事件被成功的触发了

}

}

//这个模拟被观察者

class Observable

{

//绑定到被观察者上面的观察者

private Observer observer;

//被观察者对外面提供的操作

public void test()

{

observer.test();

}

public Observer getObserver()

{

return observer;

}

public void setObserver(Observer observer)

{

this.observer = observer;

}

}

// 这个模拟观察者

class Observer

{

// 这个模拟事件

public void test()

{

System.out.println("这里就是事件。。。");

}

}

第二步:

/**

*

*/

package test;

import java.util.ArrayList;

import java.util.List;

/**

* @author LinkinPark

* @date 2015年8月31日 下午3:07:34

* @Description:

* 现在在原来的基础上稍微复杂一点,现在不在被观察者身上只绑一个观察者了。

* 现在绑定多个观察者。

*/

public class Util

{

public static void main(String[] args)

{

// 首先初始化一个被观察者,然后在初始化2个观察者

// 然后将观察者绑定到被观察者上面,然后使用被观察者看看观察者里面的事件有没有被触发

Observable observable = new Observable();

Observer observer1 = new Observer();

Observer observer2 = new Observer();

observable.registObserver(observer1);

observable.registObserver(observer2);

//调用外部事件,看看观察者里面的事件执行了没有

observable.notifyObserver("被观察者触发了操作了呢");

}

}

// 这个模拟被观察者

class Observable

{

// 绑定到被观察者上面的观察者

private List observers = new ArrayList();

// 添加一个观察者到被观察者身上

public void registObserver(Observer observer)

{

observers.add(observer);

}

// 从绑定的观察者集合中去掉当前这个

public void removeObserver(Observer observer)

{

observers.remove(observer);

}

// 定义外部执行

public void notifyObserver(String str)

{

for (Observer observer : observers)

{

observer.test(str);

}

}

}

// 这个模拟观察者

class Observer

{

// 这个模拟事件

public void test(String str)

{

System.out.println("这里就是事件-->" + str);

}

}

第三步:

/**

*

*/

package test;

import java.util.ArrayList;

import java.util.List;

/**

* @author LinkinPark

* @date 2015年8月31日 下午3:07:34

* @Description:

* 现在在原来的基础上稍微复杂一点,现在不在被观察者身上只绑一个观察者了。

* 现在绑定多个观察者。现在在稍微复杂一点,观察者和被观察者都面向接口编程,里面提供多个实现

*/

public class Util

{

public static void main(String[] args)

{

// 首先初始化一个被观察者,然后在初始化2个观察者

// 然后将观察者绑定到被观察者上面,然后使用被观察者看看观察者里面的事件有没有被触发

Iobservable observable = new Observable();

Iobserver observer = new Observer();

Iobserver observer1 = new Observer1();

observable.registObserver(observer);

observable.registObserver(observer1);

// 调用被观察者的外部事件,看看观察者里面的事件执行了没有

observable.notifyObserver("被观察者触发了操作了呢");

}

}

// 被观察者对外提供的接口,其实这里定义成抽象类,也就是模板好一点。

interface Iobservable

{

// 绑定到被观察者上面的观察者

public List observers = new ArrayList();

// 添加一个观察者到被观察者身上

void registObserver(Iobserver observer);

// 从绑定的观察者集合中去掉当前这个

void removeObserver(Iobserver observer);

// 定义外部执行

public void notifyObserver(String str);

}

// 观察者对外提供的接口。

interface Iobserver

{

// 这个模拟事件

public void test(String str);

}

// 这个模拟被观察者

class Observable implements Iobservable

{

public void registObserver(Iobserver observer)

{

observers.add(observer);

System.out.println("这里添加一个被观察者-->" + observer.getClass());

}

public void removeObserver(Iobserver observer)

{

observers.remove(observer);

System.out.println("这里溢出一个被观察者-->" + observer.getClass());

}

public void notifyObserver(String str)

{

for (Iobserver observer : observers)

{

observer.test(str);

}

}

}

// 这个模拟观察者0

class Observer implements Iobserver

{

public void test(String str)

{

System.out.println("这里就是Observer事件-->" + str);

}

}

// 这个模拟观察者1

class Observer1 implements Iobserver

{

public void test(String str)

{

System.out.println("这里就是Observer1事件-->" + str);

}

}

第四步:

/**

*

*/

package test;

import java.util.ArrayList;

import java.util.List;

/**

* @author LinkinPark

* @date 2015年8月31日 下午3:07:34

* @Description:

* 现在在原来的基础上稍微复杂一点,现在不在被观察者身上只绑一个观察者了。

* 现在绑定多个观察者。现在在稍微复杂一点,观察者和被观察者都面向接口编程,里面提供多个实现。

* 最后现在提供一个最完美的观察者模式,其实和我前面那篇博客写的差不多

*/

public class Util

{

public static void main(String[] args)

{

// 首先初始化一个被观察者,然后在初始化2个观察者

// 然后将观察者绑定到被观察者上面,然后使用被观察者看看观察者里面的事件有没有被触发

Iobservable observable = new Observable();

Iobserver observer = new Observer();

Iobserver observer1 = new Observer1();

observable.registObserver(observer);

observable.registObserver(observer1);

// 调用被观察者的外部事件,看看观察者里面的事件执行了没有

System.out.println("===========华丽丽的分割线=============");

observable.notifyObserver("LinkinPark...");

}

}

// 被观察者对外提供的接口,其实这里定义成抽象类,也就是模板好一点。

abstract class Iobservable

{

// 绑定到被观察者上面的观察者

public List observers = new ArrayList();

// 添加一个观察者到被观察者身上

abstract void registObserver(Iobserver observer);

// 从绑定的观察者集合中去掉当前这个

abstract void removeObserver(Iobserver observer);

// 通知给观察者,让其开始做相关处理

public void notifyObserver(String str)

{

for (Iobserver observer : observers)

{

observer.test(str);

}

}

}

// 观察者对外提供的接口。

interface Iobserver

{

// 这个模拟事件

public void test(String str);

}

// 这个模拟被观察者

class Observable extends Iobservable

{

private String name;

public String getName()

{

return name;

}

// 在给这个被观察者重新设值name的时候,也就说现在观察者状态发生改变了,那么就要通知给观察者,让他也来做相关的处理

public void setName(String name)

{

this.name = name;

notifyObserver(name);

}

public void registObserver(Iobserver observer)

{

observers.add(observer);

System.out.println("这里添加一个被观察者-->" + observer.getClass());

}

public void removeObserver(Iobserver observer)

{

observers.remove(observer);

System.out.println("这里移除一个被观察者-->" + observer.getClass());

}

}

// 这个模拟观察者0

class Observer implements Iobserver

{

public Observer()

{

System.out.println("Observer:观察者原来的name-->" + getName());

}

private String name = "Observer";

public String getName()

{

return name;

}

public void setName(String name)

{

this.name = name;

}

public void test(String str)

{

System.out.println("Observer:原来的name-->" + getName());

setName(str);

System.out.println("被观察者状态改变后本地的同步name-->" + getName());

}

}

// 这个模拟观察者1

class Observer1 implements Iobserver

{

public Observer1()

{

System.out.println("Observer1:观察者原来的name-->" + getName());

}

private String name = "Observer1";

public String getName()

{

return name;

}

public void setName(String name)

{

this.name = name;

}

public void test(String str)

{

System.out.println("Observer1:原来的name-->" + getName());

setName(str);

System.out.println("被观察者状态改变后本地的同步name-->" + getName());

}

}

4876c0ff7a56916ba9c2625519863483.png

最后一步:java事件监听了呢。

package test;

import java.util.ArrayList;

import java.util.EventListener;

import java.util.EventObject;

import java.util.Iterator;

import java.util.List;

/**

* @author LinkinPark

* @date 2015年9月1日 下午1:46:52

* @Description: java事件监听机制

*/

public class Linkin

{

// 初始化主题-->被观察者

DemoSource source = new DemoSource();

// 初始化监听-->观察者

DemoListener Listener1 = new Listener1();

DemoListener Listener2 = new Listener2();

public Linkin()

{

source.addDemoListener(Listener1).addDemoListener(Listener2).addDemoListener(new DemoListener()

{

@Override

public void demoEvent(DemoEvent demoEvent)

{

System.out.println("匿名内部类收到主题推送-->" + demoEvent.getSource().getClass());

}

});

System.out.println("主题原来的状态-->" + name);

}

private String name = "nameOld";

/**

* @return the name

*/

public String getName()

{

return name;

}

/**

* @param name the name to set

*/

public void setName(String name)

{

this.name = name;

System.out.println("主题现在的状态-->" + name);

source.notifyDemoEvent();

}

public static void main(String[] args)

{

new Linkin().setName("nameNew");

}

}

// 就是事件产生时具体的“事件”,用于listener的相应的方法之中,作为参数,一般存在与listerner的方法之中

class DemoEvent extends EventObject

{

private static final long serialVersionUID = 1L;

Object obj;

public DemoEvent(Object source)

{

super(source);

obj = source;

}

public Object getSource()

{

return obj;

}

}

// 具体的对监听的事件类,当有其对应的event object产生的时候,它就调用相应的方法,进行处理。

interface DemoListener extends EventListener

{

void demoEvent(DemoEvent demoEvent);

}

// 这个相当于观察者

class Listener1 implements DemoListener

{

@Override

public void demoEvent(DemoEvent demoEvent)

{

System.out.println("Listener1监听收到了主题的推送消息" + demoEvent.getSource());

}

}

// 这个相当于观察者

class Listener2 implements DemoListener

{

@Override

public void demoEvent(DemoEvent demoEvent)

{

System.out.println("Listener2监听收到了主题的推送消息" + demoEvent.getSource());

}

}

// 具体的接受事件的实体,也就是观察者模式中的被观察者。比如说,你点击一个button,那么button就是event source,

// 这样你必须使button对某些事件进行相应,你就需要注册特定的listener,比如说MouseEvent之中的MouseClicked方法,这是他就必须有了add方法

class DemoSource

{

private List repository = new ArrayList();

DemoListener dl;

public DemoSource()

{

}

// 添加监听

public DemoSource addDemoListener(DemoListener dl)

{

repository.add(dl);

return this;

}

// 状态改变被触发

public void notifyDemoEvent()

{

Iterator it = repository.iterator();

while (it.hasNext())

{

dl = (DemoListener) it.next();

dl.demoEvent(new DemoEvent(this));

}

}

}

d27744fb9254fc499b29d23ad8f2de74.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/561072.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

eq值 推荐算法_C++实现十种排序算法

十种排序算法&#xff1a;选择排序插入排序冒泡排序希尔排序快速排序的三种实现方法归并排序堆排序&#xff08;大顶堆&#xff09;计数排序基数排序&#xff08;待实现&#xff09;桶排序&#xff08;待实现&#xff09;#include <bits/stdc.h> using namespace std; vo…

python读取tiff文件进行波段计算_python+tifffile之tiff文件读写方式

背景使用python操作一批同样分辨率的图片&#xff0c;合并为tiff格式的文件。由于opencv主要用于读取单帧的tiff文件&#xff0c;对多帧的文件支持并不好。通过搜索发现了两个比较有用的包&#xff1a;TiffCapture和tifffile。两者都可用pip安装。其中前者主要用于读取tiff文件…

java 线程停止在那个为止_java停止线程

本文将介绍jdk提供的api中停止线程的用法。停止一个线程意味着在一个线程执行完任务之前放弃当前的操作&#xff0c;停止一个线程可以使用Thread.stop()方法&#xff0c;但是做好不要使用它&#xff0c;它是后继jdk版本中废弃的或者将不能使用的方法&#xff0c;大多数停止一个…

java中的action是指什么_Struts2【开发Action】知识要点

前言前面Struts博文基本把Struts的配置信息讲解完了.....本博文主要讲解Struts对数据的处理Action开发的三种方式在第一次我们写开发步骤的时候&#xff0c;我们写的Action是继承着ActionSupport类的...为啥我们继承了ActionSupport类呢&#xff1f;下面我就会讲解到继承Action…

hql 查询条件 set集合_Redis从入门到深入-Sorted_set的value

1. sorted_set 类型新的存储需求&#xff0c;数据排序有利于数据的有效展示&#xff0c;需要提供一种可以根据自身特征进行排序的方式需要的存储结构&#xff1a;新的存储模型&#xff0c;可以保存可排序的数据sorted_set类型&#xff1a;在set的存储结构基础上添加可排序字段2…

pdm生成java_PowerDesigner通过SQL语句生成PDM文件并将name和comment进行互相转换

本篇文章主要介绍了PowerDesigner通过SQL语句生成PDM文件并将name和comment进行互相转换 超详细过程(图文)&#xff0c;具有一定的参考价值&#xff0c;感兴趣的小伙伴们可以参考一下1.软件准备软件&#xff1a;Navicat 11.1&#xff0c;Powerdesigner 152.安装步骤第一步&…

python逐步回归筛选变量_Python实现逐步回归(stepwise regression)

逐步回归的基本思想是将变量逐个引入模型&#xff0c;每引入一个解释变量后都要进行F检验&#xff0c;并对已经选入的解释变量逐个进行t检验&#xff0c;当原来引入的解释变量由于后面解释变量的引入变得不再显著时&#xff0c;则将其删除。以确保每次引入新的变量之前回归方程…

java里面如何加入高级的东西_如何成为一名Java高级架构师

近些年来互联网快速发展&#xff0c;现阶段的数据量和高并发的诉求&#xff0c;引起了不少传统的技术人员的力不从心&#xff0c;企业愈发关注到了系统架构的重要性&#xff0c;既需要掌控整体又需要洞悉局部瓶颈并依据具体的业务场景给出解决方案的领导型人物——Java架构师应…

mysql获取最好成绩对应数据的其他项_开源数据同步神器——canal

前言如今大型的IT系统中&#xff0c;都会使用分布式的方式&#xff0c;同时会有非常多的中间件&#xff0c;如redis、消息队列、大数据存储等&#xff0c;但是实际核心的数据存储依然是存储在数据库&#xff0c;作为使用最广泛的数据库&#xff0c;如何将mysql的数据与中间件的…

java怎么使用floor_Java floor() 方法

floor() 方法可对一个数进行下舍入&#xff0c;返回给定参数最大的整数&#xff0c;该整数小于或等给定的参数。语法该方法有以下几种语法格式&#xff1a;double floor(double d)double floor(float f)参数double 或 float 的原生数据类型。返回值返回 double 类型数组&#x…

python外部库是什么_如何使用Portable Python安装外部库?

由于管理员权限,我无法在我的机器上安装Python,但我成功下载/打开了Portable Python.我在Windows 7 64位机器上.我怎样才能使用以前的外部库,比如Numpy或Gmpy&#xff1f;解决方法:easy_install正在尝试从源代码安装. gmpy和gmpy2是C扩展,需要兼容的C编译器和其他库(GMP;以及gm…

java创建目录时带权限_java – 无法在外部存储中创建目录,尽管权限显然设置正确...

我有在我的清单文件中,但是尝试创建一个目录时我失败了Log.d(LOG_STRING, android.os.Environment.getExternalStorageState() );java.io.File folder new java.io.File(Environment.getExternalStorageDirectory() java.io.File.separator "test");boolean succe…

window访问不到linux的activemq_springboot整合开源项目测试拦截接口访问的频率

本节目标本篇文章主要是介绍以下springboot整合开源项目&#xff0c;实现反爬虫接口防刷的demo&#xff0c;额外的介绍一下axios的基本用法&#xff1b;所以本篇文章阅读起来相对轻松。OK&#xff0c;下面开始整合.引入项目依赖cn.keking.project kk-anti-reptile …

java 数据库外键查询_oracle中查询所有外键引用到某张表的记录

其实查找这篇文章 我主要用的sql 是这句 select * from user_cons_columns t where t.constraint_name like FK_CTS_CONT_REINS__CRR;起因&#xff1a;系统测试的时候发现如果某条记录已经被引用了&#xff0c;这个时候删除这条记录会引起数据不一致&#xff0c;系统会报错。…

sql server限制查询条数_18. Django 2.1.7 查询集 QuerySet

上一篇Django 2.1.7 模型 - 条件查询 F对象 Q对象 聚合查询讲述了关于Django模型的介绍F对象、Q对象、聚合查询等功能。不管什么查询&#xff0c;返回的结果都基本是查询集QuerySet&#xff0c;如下&#xff1a;In [16]: MiddlewareInfo.objects.all()Out[16]: 1)>, 2)>,…

python文件传输socket_树莓派采用socket方式文件传输(python)

两个树莓派&#xff0c;在同一个局域网内&#xff0c;传输文件&#xff0c;采用socket方式。client端代码&#xff1a;import socketimport osimport hashlibclient socket.socket() # 生成socket&#xff0c;连接serverip_port ("192.168.137.210",12346) # server…

java 过滤列表_Java 8 Stream过滤列表中列表的值

我有一个看起来如下的对象class MyObject {String type;List subTypes;}是否有可能,给定一个MyObject列表,使用Java 8流来过滤类型和子类型&#xff1f;到目前为止我有myObjects.stream().filter(t -> t.getType().equals(someotherType).collect(Collections.toList());但在…

python实现程序重启_python实现自动重启本程序的方法

#!/usr/local/bin/python#-*- coding: UTF-8 -*-##################################################################### python 自动重启本程序#####################################################################import os,time#def close():# print "程序重启&a…

java调用 restapi 乱码_Java HttpURLConnection模拟请求Rest接口解决中文乱码问题

public staticString PostRequest(String URL,String obj) {String jsonString"";try{//创建连接URL url newURL(URL);HttpURLConnection connection(HttpURLConnection) url.openConnection();connection.setDoOutput(true);connection.setDoInput(true);connectio…

python惰性求值的特点_C#教程之C#函数式编程中的惰性求值详解

https://www.xin3721.com/eschool/python.html惰性求值在开始介绍今天要讲的知识之前&#xff0c;我们想要理解严格求值策略和非严格求值策略之间的区别&#xff0c;这样我们才能够深有体会的明白为什么需要利用这个技术。首先需要说明的是C#语言小部分采用了非严格求值策略&am…