java监听器
2020-11-27 04:11
标签:style blog class code java ext 一、先看看jdk提供的event包: public class EventObject extends Object implements
Serializable所有事件状态对象都将从其派生的根类。 所有 Event 在构造时都引用了对象
"source",在逻辑上认为该对象是最初发生有关 Event 的对象。 监听器接口定义了一个类要成为监听器必须具备的功能。所有的监听器接口也都必须继承监听器接口基类
java.util.EventListener;EventListener本身没有定义任何方法,它只是一个标志接口,用来表明所有继承自
EventListener的接口属于监听器接口。 监听器是监听器接口的实现者,提供监听器接口中定义的所有方法的实现代码。简单情形下,一个监听器只监听一种类型的事件,即实现一种监听器接口。复杂的监
听器可以实现多种监听器接口,监听多种类型的事件。在事件处理方法代码中,监听器可以从入口参数中获得事件对象,并通过该对象获得所需的信息,例如事件
源、事件发生时间等等。事件源是一定可以从事件对象中
获得的,因为事件基类EventObject提供了getSource()方法,除此以外,能从事件对象中获得的信息,取决于事件类的定义。 当事件对象被产生后,事件源必须向所有的注册监听器广播该消息。事件的广播,是通过逐个调用监听器列表中所有监听器的事件处理方法来实现的。 在Java的事件驱动模式中,事件源是最复杂的。多数情况下,程序员只需编写监听器的代码,而并不需要编写事件源代码。 1、定义自己业务相关的事件: 2、相应的事件监听器接口,和实现类 实现类 3、事件源,必须要有注册、注销监听器的方法 4、main Reference java事件处理机制(自定义事件)【转】 http://my.oschina.net/lzwenme/blog/159864 java监听器,搜素材,soscw.com java监听器 标签:style blog class code java ext 原文地址:http://www.cnblogs.com/549294286/p/3703340.html
public interface
EventListener:所有事件侦听器接口必须扩展的标记接口。package java.util;
/**
* A tagging interface that all event listener interfaces must extend.
* @since JDK1.1
*/
public interface EventListener {
}
package java.util;
public class EventObject implements java.io.Serializable {
private static final long serialVersionUID = 5516075349620653480L;
/**
* The object on which the Event initially occurred.
*/
protected transient Object source;
/**
* Constructs a prototypical Event.
*
* @param source The object on which the Event initially occurred.
* @exception IllegalArgumentException if source is null.
*/
public EventObject(Object source) {
if (source == null)
throw new IllegalArgumentException("null source");
this.source = source;
}
public Object getSource() {
return source;
}
}
监听器接口定义了监听器必须实现的方法。事件处理方法以事件对象作为入口参数,包含对事件进行处理的代码,方法名称任意,如processEvent或者handleEvent之类。
作为事件源的类,必需满足以下条件:
事件源必须在内部维护一个已注册监听器的列表。当某监听器注册时,该监听器被添加到列表中,而监听器注销时,则从列表中删除;
事件源必须提供注册方法,以允许监听器注册为事件的接收者;
事件源必须提供注销方法,以允许监听器注销,停止对事件的接收;
事件源必须能够实例化事件类,即产生事件对象;二、代码实现
package test.listener;
import java.util.EventObject;
public class DoorEvent extends EventObject {
private String doorState = "open";
public DoorEvent(Object source) {
super(source);
}
public DoorEvent(Object source, String state) {
super(source);
doorState = state;
}
public String getDoorState() {
return doorState;
}
public void setDoorState(String doorState) {
this.doorState = doorState;
}
}
package test.listener;
import java.util.EventListener;
public interface DoorListener extends EventListener{
public void doorOpen(DoorEvent event);
}
package test.listener;
public class DoorListenerImpl implements DoorListener {
@Override
public void doorOpen(DoorEvent event) {
if (event.getDoorState()!=null && event.getDoorState().equals("open")) {
System.out.println("door is open");
}
else {
System.out.println("door is closed");
}
}
}
package
test.listener;
import
java.util.HashSet;
import
java.util.Set;
public
class
DoorManager {
private
Set
public
void
addDoorListener(DoorListener listener) {
if
(
null
== listeners) listeners =
new
HashSet
listeners.add(listener);
}
public
void
removeDoorListener(DoorListener listener) {
if
(listeners ==
null
)
return
;
listeners.remove(listener);
}
protected
void
fireWorkspaceOpened() {
if
(listeners ==
null
)
return
;
DoorEvent event =
new
DoorEvent(
this
,
"open"
);
notifyListener(event);
}
protected
void
fireWorkspaceClosed() {
if
(listeners ==
null
)
return
;
DoorEvent event =
new
DoorEvent(
this
,
"closed"
);
notifyListener(event);
}
private
void
notifyListener(DoorEvent event) {
for
(DoorListener listener : listeners) {
listener.doorOpen(event);
}
}
}
package test.listener;
public class App {
public static void main(String[] args) {
DoorManager manager = new DoorManager();
manager.addDoorListener(new DoorListenerImpl());
manager.addDoorListener(new DoorListener() {
@Override
public void doorOpen(DoorEvent event) {
System.out.println("break the door");
}
});
//
manager.fireWorkspaceOpened();
//
manager.fireWorkspaceClosed();
}
}
Java
中 Listener监听器作用和过滤器的作用,以及区别