事件

具体代表者是:ApplicationEvent:

1、其继承自JDK的EventObject,JDK要求所有事件将继承它,并通过source得到事件源,比如我们的AWT事件体系也是继承自它;

2、系统默认提供了如下ApplicationEvent事件实现:

只有一个ApplicationContextEvent,表示ApplicationContext容器事件,且其又有如下实现:

ContextStartedEvent:ApplicationContext启动后触发的事件;(目前版本没有任何作用)
ContextStoppedEvent:ApplicationContext停止后触发的事件;(目前版本没有任何作用)
ContextRefreshedEvent:ApplicationContext初始化或刷新完成后触发的事件;(容器初始化完成后调用)
ContextClosedEvent:ApplicationContext关闭后触发的事件;(如web容器关闭时自动会触发spring容 器的关闭,如果是普通java应用,需要调用ctx.registerShutdownHook();注册虚拟机关闭时的钩子才行)
注:org.springframework.context.support.AbstractApplicationContext抽象类实现 了LifeCycle的start和stop回调并发布ContextStartedEvent和ContextStoppedEvent事件;但是无任 何实现调用它,所以目前无任何作用。

目标(发布事件者)

具体代表者是:ApplicationEventPublisher及ApplicationEventMulticaster,系统默认提供了如下实现:

1、 ApplicationContext接口继承了ApplicationEventPublisher,并在 AbstractApplicationContext实现了具体代码,实际执行是委托给ApplicationEventMulticaster(可以 认为是多播):

public void publishEvent(ApplicationEvent event) {
 //省略部分代码
 }
 getApplicationEventMulticaster().multicastEvent(event);
 if (this.parent != null) {
 this.parent.publishEvent(event);
 }
 }


我们常用的ApplicationContext都继承自AbstractApplicationContext,如ClassPathXmlApplicationContext、XmlWebApplicationContext等。所以自动拥有这个功能。

2、ApplicationContext自动到本地容器里找一个名字为”“的ApplicationEventMulticaster实现,如果 没有自己new一个SimpleApplicationEventMulticaster。其中 SimpleApplicationEventMulticaster发布事件的代码如下:

public void multicastEvent(final ApplicationEvent event) {
 for (final ApplicationListener listener : getApplicationListeners(event)) {
 Executor executor = getTaskExecutor();
 if (executor != null) {
 executor.execute(new Runnable() {
 public void run() {
 listener.onApplicationEvent(event);
 }
 });
 }
 else {
 listener.onApplicationEvent(event);
 }
 }
 }


大家可以看到如果给它一个executor(java.util.concurrent.Executor),它就可以异步支持发布事件,否则就是同步。

所以我们发送事件只需要通过ApplicationContext.publishEvent即可,没必要再创建自己的实现了。除非有必要。

监听器

具体代表者是:ApplicationListener

1、其继承自JDK的EventListener,JDK要求所有监听器将继承它,比如我们的AWT事件体系也是继承自它;

2、ApplicationListener接口:

public interface ApplicationListener extends EventListener {
 void onApplicationEvent(E event);
 }


其只提供了onApplicationEvent方法,我们需要在该方法实现内部判断事件类型来处理,也没有提供按顺序触发监听器的语义,所以Spring提供了另一个接口,SmartApplicationListener:

public interface SmartApplicationListener extends ApplicationListener, Ordered {
//如果实现支持该事件类型 那么返回true
boolean supportsEventType(Class<? extends ApplicationEvent> eventType);

//如果实现支持“目标”类型,那么返回true  
boolean supportsSourceType(Class<?> sourceType);  
     
    //顺序,即监听器执行的顺序,值越小优先级越高  
    int getOrder();

该接口可方便实现去判断支持的事件类型、目标类型,及执行顺序。