java 监听器

摘要:
PublicclassEventObjectextendsObjectimplementsSerializable所有事件状态对象将从中派生的根类。当Java2处理事件时,它不使用dispatchEvent()-postEvent()-handleEvent()方法。它使用侦听器类。每个事件类都有一个关联的侦听器接口。随着事件的发生,相应的状态通常封装在事件状态对象中,该对象必须从java继承。utilEventObject事件状态对象作为单个参数传递给响应事件的侦听器方法。对于这样的事件和这样的事件的听众,我们只能自己做。

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中就没有定义。对于这样的事件,以及对于这样的事件的监听器,我们只能自己动手完成了。
那么下面就以实例开始我们这个“创新”的过程:首先,我们要明确jdk中需要的资源:类EventObject作为父类用来生成我们自己的事件类,接口EventListener用来实现我们自己的监听器;剩下的事情就是如何注册这些事件以及测试他们了。

(1)        通过DemoEvent.java文件创建DemoEvent类,这个类继承EventObject。这个类的构造函数的参数传递了产生这个事件的事件源(比如各种控件),方法getSource用来获得这个事件源的引用。

DemoEvent.java

package demo.listener;

import java.util.EventObject;

public class DemoEvent extends EventObject

{

        Object obj;

        public DemoEvent(Object  source)

        {

                super(source);

               obj =  source;

        }

        public Object  getSource()

        {

               return  obj;

        }

        public void  say()

        {

               System.out.println("This is say  method...");

        }

}

 

(2)定义新的事件监听接口,该接口继承自EventListener;该接口包含对DemeEvent事件的处理程序:

DemoListener.java

package  demo.listener;

import  java.util.EventListener;

public interface DemoListener extends  EventListener

{

       public void demoEvent(DemoEvent  dm);

}

 

通过上面的接口我们再定义事件监听类,这些类具体实现了监听功能和事件处理功能。回想一下上文中那四种实现方式,我们这里不正是使用了其中的第三种——外部类写法的方式吗?

Listener1.java

package  demo.listener;

public class Listener1 implements  DemoListener

{

       public void demoEvent(DemoEvent  de)

       {

               System.out.println("Inside listener1...");

       }

}


Listener2.java

package  demo.listener;

public class Listener2 implements  DemoListener

{

       public void demoEvent(DemoEvent  de)

       {

               System.out.println("Inside listener2...");

       }

}

Listener3.java

package  demo.listener;

public class Listener3 implements  DemoListener

{

       public void demoEvent(DemoEvent  de)

       {

               System.out.println("Inside listener3...");

       }

}

 

(3)通过DemeSource..ava文件创造一个事件源类,它用一个java.utile.Vector对象来存储所有的事件监听器对象,存储方式是通过addListener(..)这样的方法。notifyDemeEvent(..)是触发事件的方法,用来通知系统:事件发生了,你调用相应的处理函数(回调函数)吧。

DemoSource.java

package  demo.listener;

import java.util.*;

public class  DemoSource

{

       private Vector repository = new  Vector();

       DemoListener  dl;

       public  DemoSource()

       {

       }

       public void  addDemoListener(DemoListener dl)

       {

               repository.addElement(dl);

       }

       public void  notifyDemoEvent()

       {

              Enumeration enum =  repository.elements();

               while(enum.hasMoreElements())

              {

                    dl =  (DemoListener)enum.nextElement();

                    dl.demoEvent(new  DemoEvent(this));

              }

       }

}

 

 

(4)好了,最后写一个测试程序测试一下我们自定义的事件吧,这段程序应该不难理解吧:)

TestDemo.java

package  demo.listener;

public class  TestDemo

{

       DemoSource  ds;

       public  TestDemo()

       {

              try{

                    ds = new  DemoSource();

                    Listener1 l1 = new  Listener1();

                    Listener2 l2 = new  Listener2();

                    Listener3 l3 = new  Listener3();

                     ds.addDemoListener(l1);

                     ds.addDemoListener(l2);

                     ds.addDemoListener(l3);

                    ds.addDemoListener(new  DemoListener(){                                public void  demoEvent(DemoEvent  event){                                          System.out.println("Method  come from 匿名类...");                                }                        });

ds.notifyDemoEvent();

              }catch(Exception  ex)

               {ex.printStackTrace();}

       }

       public static void main(String  args[])

       {

              new  TestDemo();

       }

}

免责声明:文章转载自《java 监听器》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇9.8Go之函数之宕机(panic)JQuery Css("borderColor") 在 FireFox 下取不到值 原因及解决。下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

【Oracle11g】06_网络配置

目录 1.Oracle11g在windows上访问的两种方式 1.1 通过网络访问 1.2 本地直接访问 2.客户端访问服务器 2.1 监听相关内容2.1.1 listener.ora的作用 2.2 sqlnet.ora的作用 2.2.1 SQLNET.AUTHENTICATION_SERVICES参数 2.2.2 NAMES.DIRE...

Android的两种事件处理机制

UI编程通常都会伴随事件处理,Android也不例外,它提供了两种方式的事件处理:基于回调的事件处理和基于监听器的事件处理。 对于基于监听器的事件处理而言,主要就是为Android界面组件绑定特定的事件监听器;对于基于回调的事件处理而言,主要做法是重写Android组件特定的回调函数,Android大部分界面组件都提供了事件响应的回调函数,我们主要重写它们...

ZK框架笔记5、事件

        事件是org.zkoss.zk.ui.event.Event类,它通知应用程序发生了什么事情。每一种类型的事件都由一个特定的类来表示。         要响应一个事件,应用程序必须为事件注册一个或更多事件监听器。有3种方式可以为一个组件事件监听器。   (1)一般制定onXXX事件监听器为组件的属性,作为属性定义的事件监听器。 &...

‎Cocos2d-x 学习笔记(15.1) EventDispatcher

EventDispatcher对监听器进行管理,围绕着监听器工作。可以添加、删除、暂停/恢复监听器、分发事件到监听器。 1. 一些成员 /** 把ListenerID和同ID监听器的容器对应 */ std::unordered_map<EventListener::ListenerID, EventListenerVector*>...

XD 05

项目启动方式 1. 在 springBoot application 上右键 run as Java application 2. run as mvn install 会打包一个jar 包 3. war 在 tomcat, war 包方式, 一般 springBoot 都是使用 jar 包启动了 a. 首先在 pom 文件中添加 <packagin...

浅析Android动画(二),属性动画高级实例探究

转载请注明出处!http://www.cnblogs.com/wondertwo/p/5312482.html ObjectAnimator实现属性动画 为了写好Android动画这几篇博客,在动笔之前我是下过很大决心的,我对自己的要求是尽量把一个小知识点写清楚写明白,说白了就是相对于大而全的长篇大论,我更倾向于去写小而美的博客!为了保证在高产的同时能坚...