swing – 为什么EventListenerList在fireFooXXX()中向后遍历?

我不理解这段代码的基本原理,取自 javax.swing.event.EventListenerList文档:
protected void fireFooXXX() {
    // Guaranteed to return a non-null array
    Object[] listeners = listenerList.getListenerList();
    // Process the listeners last to first,notifying
    // those that are interested in this event
    for (int i = listeners.length-2; i>=0; i-=2) {
        if (listeners[i]==FooListener.class) {
            // Lazily create the event:
            if (fooEvent == null)
                fooEvent = new FooEvent(this);                 
            ((FooListener)listeners[i+1]).fooXXX(fooEvent);
        }
    }
}

>为什么列表会向后移动?
>为什么只有每一个听众被叫?

事件解雇在javax.swing.tree.DefaultTreeModel等等中以这种方式实施,所以显然我只是没有得到什么.

解决方法

>可能性能考虑因素:向后迭代更快,因为与0进行比较是一个单一的机器代码指令 – 许多以前的C程序员已经根深蒂固,尽管它现在相当无关紧要.请注意,无论如何都无法保证听众的通知顺序. >查看类的其余部分 – 它还存储侦听器的类型以提供类型安全性.

相关文章

应用场景 C端用户提交工单、工单创建完成之后、会发布一条工...
线程类,设置有一个公共资源 package cn.org.chris.concurre...
Java中的数字(带有0前缀和字符串)
在Java 9中使用JLink的目的是什么?
Java Stream API Filter(过滤器)
在Java中找到正数和负数数组元素的数量