Java事件处理与发送

任何时候,按下键盘或鼠标的键就产生了事件。组件接受和处理事件的方式自JDK1.1以来都保持不变。Swing组件能够产生许多不同类别的事件,包括那些在java.awt.event包以及在javax.swing.event包中的事件。Swing新引入的那些事件类别往往是与特定Swing组件相关的。每一个事件类别都是一个对象,它至少指明了事件的发生源,往往还带有其它消息,如该事件的类别、在事件发生前和发生后事件源状态的变化,等等。事件源大部分是普通的组件或模型(models, 即MVC中的M,在以后的blog中可能会介绍Swing组件的MVC结构)。其它的对象也可能产生事件。

要想收到事件产生的通知,我们需要在目标对象上注册事件监听器。事件监听器是任意XXListener类或接口的具体实现(XX代指事件的类型)。XXListener是定义在java.awt.event、java.beans和javax.swing.event包中的类或接口。在每个接口中至少定义了一个方法(method),该方法以对应的XXEvent作为参数。支持发送XXEvent事件发生通知的类都须实现XXListener接口,同时提供相应的addXXListener()和removeXXListener()方法来注册和移除这些事件监听器,大部分的事件目标对象(target)都允许注册任意多个事件监听器。通常支持XXEvent的类都提供受保护的方法(protected method)fireXX()来构造事件对象及将它送至事件处理器(event handler)进行处理。

javax.swing.event.EventListenerList类

EventListenerList是一个包含XXEvent/XXListener对(pairs)的阵列(数组)。JComponent及其派生类使用一个EventListenerList对象来维护其事件监听器。所有默认的模型(models)同样维护事件监听器和一个EventListenerList。当一个监听器被注册到一个Swing组件或模型(model)时,对应的事件的Class实例(用来标识事件类别)被添加至EventListenerList阵列,后面紧随该监听器本身(即一个XXEvent/XXListener对)。因为这些对是储存在阵列而不是在可变的集合(mutable collection)中(出于对效率的考虑),每一次添加和移除都会调用System.arrayCopy()来生成一个新的阵列。当收到事件时,阵列被遍历,事件就会被送至拥有其类型的每一个事件监听器。由于阵列是按XXEvent, XXListener, YYEvent, YYListener, ... 的方式排列的,某个事件类别的监听器总是紧随其后。这种方式使得事件处理十分高效。为了线程安全,当从EventListenerList添加和移除监听器时,方法访问阵列必须同步。

JComponent定义了一个名为listenerList的受保护EventListListener属性,因而所有它的子类都继承了这个属性。Swing组件直接透过listenerList属性来管理其大部分事件监听器。

事件发送线程

事件监听器在事件发送线程(一个java.awt.EventDispatchThread类的实例)中接受并处理事件。所有的绘制和组件布局也被要求在此线程中发生。事件发送线程在AWT和Swing中具有头等的重要性,在应用中控制组件状态和显示的随时更新方面扮演着关键的角色。

与此线程相关的是一个事件的FIFO(First In First Out,先进先出)队列:系统事件队列(java.awt.EventQueue的一个实例)。跟所有的FIFO队列一样,系统事件队列也是被线性填充的。无论是更新组件属性,布局,或是重新绘制,每一个请求依次运行事件处理代码。所有事件被依次处理是为了避免像某个组件的状态在它重新绘制的中途被意外改变这样的情况。知道这一点后,我们就要避免在事件发送线程之外去发送事件。比如说,在另一个线程中直接调用fireXX()方法就是不安全的。我们同时也必须保证事件处理代码和绘制代码尽快地执行完,否则整个系统队列就会被阻塞,被迫等待某个事件被处理,重新绘制,或是布局完毕,而我们的应用程序则像是被“冻结”或是失去响应。
==============================================================================================
// Thanks to Matthew Robinson and Pavel Vorobiev, Ph.D for their great book Swing, this article is translated form
// this book, 1st edition. You can find these text in their book (in English) of Chapter 2.
=================================================================================

要想收到事件产生的通知,我们需要在目标对象上注册事件监听器。事件监听器是任意XXListener类或接口的具体实现(XX代指事件的类型)。XXListener是定义在java.awt.event、java.beans和javax.swing.event包中的类或接口。在每个接口中至少定义了一个方法(method),该方法以对应的XXEvent作为参数。支持发送XXEvent事件发生通知的类都须实现XXListener接口,同时提供相应的addXXListener()和removeXXListener()方法来注册和移除这些事件监听器,大部分的事件目标对象(target)都允许注册任意多个事件监听器。通常支持XXEvent的类都提供受保护的方法(protected method)fireXX()来构造事件对象及将它送至事件处理器(event handler)进行处理。

javax.swing.event.EventListenerList类

EventListenerList是一个包含XXEvent/XXListener对(pairs)的阵列(数组)。JComponent及其派生类使用一个EventListenerList对象来维护其事件监听器。所有默认的模型(models)同样维护事件监听器和一个EventListenerList。当一个监听器被注册到一个Swing组件或模型(model)时,对应的事件的Class实例(用来标识事件类别)被添加至EventListenerList阵列,后面紧随该监听器本身(即一个XXEvent/XXListener对)。因为这些对是储存在阵列而不是在可变的集合(mutable collection)中(出于对效率的考虑),每一次添加和移除都会调用System.arrayCopy()来生成一个新的阵列。当收到事件时,阵列被遍历,事件就会被送至拥有其类型的每一个事件监听器。由于阵列是按XXEvent, XXListener, YYEvent, YYListener, ... 的方式排列的,某个事件类别的监听器总是紧随其后。这种方式使得事件处理十分高效。为了线程安全,当从EventListenerList添加和移除监听器时,方法访问阵列必须同步。

JComponent定义了一个名为listenerList的受保护EventListListener属性,因而所有它的子类都继承了这个属性。Swing组件直接透过listenerList属性来管理其大部分事件监听器。

事件发送线程

事件监听器在事件发送线程(一个java.awt.EventDispatchThread类的实例)中接受并处理事件。所有的绘制和组件布局也被要求在此线程中发生。事件发送线程在AWT和Swing中具有头等的重要性,在应用中控制组件状态和显示的随时更新方面扮演着关键的角色。

与此线程相关的是一个事件的FIFO(First In First Out,先进先出)队列:系统事件队列(java.awt.EventQueue的一个实例)。跟所有的FIFO队列一样,系统事件队列也是被线性填充的。无论是更新组件属性,布局,或是重新绘制,每一个请求依次运行事件处理代码。所有事件被依次处理是为了避免像某个组件的状态在它重新绘制的中途被意外改变这样的情况。知道这一点后,我们就要避免在事件发送线程之外去发送事件。比如说,在另一个线程中直接调用fireXX()方法就是不安全的。我们同时也必须保证事件处理代码和绘制代码尽快地执行完,否则整个系统队列就会被阻塞,被迫等待某个事件被处理,重新绘制,或是布局完毕,而我们的应用程序则像是被“冻结”或是失去响应。
==============================================================================================
// Thanks to Matthew Robinson and Pavel Vorobiev, Ph.D for their great book Swing, this article is translated form
// this book, 1st edition. You can find these text in their book (in English) of Chapter 2.
=================================================================================

要想收到事件产生的通知,我们需要在目标对象上注册事件监听器。事件监听器是任意XXListener类或接口的具体实现(XX代指事件的类型)。XXListener是定义在java.awt.event、java.beans和javax.swing.event包中的类或接口。在每个接口中至少定义了一个方法(method),该方法以对应的XXEvent作为参数。支持发送XXEvent事件发生通知的类都须实现XXListener接口,同时提供相应的addXXListener()和removeXXListener()方法来注册和移除这些事件监听器,大部分的事件目标对象(target)都允许注册任意多个事件监听器。通常支持XXEvent的类都提供受保护的方法(protected method)fireXX()来构造事件对象及将它送至事件处理器(event handler)进行处理。

javax.swing.event.EventListenerList类

EventListenerList是一个包含XXEvent/XXListener对(pairs)的阵列(数组)。JComponent及其派生类使用一个EventListenerList对象来维护其事件监听器。所有默认的模型(models)同样维护事件监听器和一个EventListenerList。当一个监听器被注册到一个Swing组件或模型(model)时,对应的事件的Class实例(用来标识事件类别)被添加至EventListenerList阵列,后面紧随该监听器本身(即一个XXEvent/XXListener对)。因为这些对是储存在阵列而不是在可变的集合(mutable collection)中(出于对效率的考虑),每一次添加和移除都会调用System.arrayCopy()来生成一个新的阵列。当收到事件时,阵列被遍历,事件就会被送至拥有其类型的每一个事件监听器。由于阵列是按XXEvent, XXListener, YYEvent, YYListener, ... 的方式排列的,某个事件类别的监听器总是紧随其后。这种方式使得事件处理十分高效。为了线程安全,当从EventListenerList添加和移除监听器时,方法访问阵列必须同步。

JComponent定义了一个名为listenerList的受保护EventListListener属性,因而所有它的子类都继承了这个属性。Swing组件直接透过listenerList属性来管理其大部分事件监听器。

事件发送线程

事件监听器在事件发送线程(一个java.awt.EventDispatchThread类的实例)中接受并处理事件。所有的绘制和组件布局也被要求在此线程中发生。事件发送线程在AWT和Swing中具有头等的重要性,在应用中控制组件状态和显示的随时更新方面扮演着关键的角色。

与此线程相关的是一个事件的FIFO(First In First Out,先进先出)队列:系统事件队列(java.awt.EventQueue的一个实例)。跟所有的FIFO队列一样,系统事件队列也是被线性填充的。无论是更新组件属性,布局,或是重新绘制,每一个请求依次运行事件处理代码。所有事件被依次处理是为了避免像某个组件的状态在它重新绘制的中途被意外改变这样的情况。知道这一点后,我们就要避免在事件发送线程之外去发送事件。比如说,在另一个线程中直接调用fireXX()方法就是不安全的。我们同时也必须保证事件处理代码和绘制代码尽快地执行完,否则整个系统队列就会被阻塞,被迫等待某个事件被处理,重新绘制,或是布局完毕,而我们的应用程序则像是被“冻结”或是失去响应。
==============================================================================================
// Thanks to Matthew Robinson and Pavel Vorobiev, Ph.D for their great book Swing, this article is translated form
// this book, 1st edition. You can find these text in their book (in English) of Chapter 2.
=================================================================================

JDK1.1以来都保持不变。Swing组件能够产生许多不同类别的事件,包括那些在java.awt.event包以及在javax.swing.event包中的事件。Swing新引入的那些事件类别往往是与特定Swing组件相关的。每一个事件类别都是一个对象,它至少指明了事件的发生源,往往还带有其它消息,如该事件的类别、在事件发生前和发生后事件源状态的变化,等等。事件源大部分是普通的组件或模型(models, 即MVC中的M,在以后的blog中可能会介绍Swing组件的MVC结构)。其它的对象也可能产生事件。

要想收到事件产生的通知,我们需要在目标对象上注册事件监听器。事件监听器是任意XXListener类或接口的具体实现(XX代指事件的类型)。XXListener是定义在java.awt.event、java.beans和javax.swing.event包中的类或接口。在每个接口中至少定义了一个方法(method),该方法以对应的XXEvent作为参数。支持发送XXEvent事件发生通知的类都须实现XXListener接口,同时提供相应的addXXListener()和removeXXListener()方法来注册和移除这些事件监听器,大部分的事件目标对象(target)都允许注册任意多个事件监听器。通常支持XXEvent的类都提供受保护的方法(protected method)fireXX()来构造事件对象及将它送至事件处理器(event handler)进行处理。

javax.swing.event.EventListenerList类

EventListenerList是一个包含XXEvent/XXListener对(pairs)的阵列(数组)。JComponent及其派生类使用一个EventListenerList对象来维护其事件监听器。所有默认的模型(models)同样维护事件监听器和一个EventListenerList。当一个监听器被注册到一个Swing组件或模型(model)时,对应的事件的Class实例(用来标识事件类别)被添加至EventListenerList阵列,后面紧随该监听器本身(即一个XXEvent/XXListener对)。因为这些对是储存在阵列而不是在可变的集合(mutable collection)中(出于对效率的考虑),每一次添加和移除都会调用System.arrayCopy()来生成一个新的阵列。当收到事件时,阵列被遍历,事件就会被送至拥有其类型的每一个事件监听器。由于阵列是按XXEvent, XXListener, YYEvent, YYListener, ... 的方式排列的,某个事件类别的监听器总是紧随其后。这种方式使得事件处理十分高效。为了线程安全,当从EventListenerList添加和移除监听器时,方法访问阵列必须同步。

JComponent定义了一个名为listenerList的受保护EventListListener属性,因而所有它的子类都继承了这个属性。Swing组件直接透过listenerList属性来管理其大部分事件监听器。

事件发送线程

事件监听器在事件发送线程(一个java.awt.EventDispatchThread类的实例)中接受并处理事件。所有的绘制和组件布局也被要求在此线程中发生。事件发送线程在AWT和Swing中具有头等的重要性,在应用中控制组件状态和显示的随时更新方面扮演着关键的角色。

与此线程相关的是一个事件的FIFO(First In First Out,先进先出)队列:系统事件队列(java.awt.EventQueue的一个实例)。跟所有的FIFO队列一样,系统事件队列也是被线性填充的。无论是更新组件属性,布局,或是重新绘制,每一个请求依次运行事件处理代码。所有事件被依次处理是为了避免像某个组件的状态在它重新绘制的中途被意外改变这样的情况。知道这一点后,我们就要避免在事件发送线程之外去发送事件。比如说,在另一个线程中直接调用fireXX()方法就是不安全的。我们同时也必须保证事件处理代码和绘制代码尽快地执行完,否则整个系统队列就会被阻塞,被迫等待某个事件被处理,重新绘制,或是布局完毕,而我们的应用程序则像是被“冻结”或是失去响应。
==============================================================================================
// Thanks to Matthew Robinson and Pavel Vorobiev, Ph.D for their great book Swing, this article is translated form
// this book, 1st edition. You can find these text in their book (in English) in Chapter 2.
=================================================================================

时间: 2024-10-02 12:35:29

Java事件处理与发送的相关文章

使用Java制作多点发送程序

IP协议是Internet上所有信息的传播手段,UDP(User Datagram Protocol,用户数据报协议)数据报被封装在IP包中,发送到网络上适当的机器.众所周知,大多数IP使用单点发送,即从一个主机发送一个包到另一个主机上.然而,IP协议也具有多点发送的能力,若要使用多点发送时,一个报文标有一组目标主机地址,当报文发出后,整个组都能收到.为支持多点发送,一定范围的IP地址被单独划分出来.这些IP地址是D类地址,其范围是224.0.0.0至239.255.255.255. IP多点发

Java实现邮件发送遇到的问题_java

发送邮件的代码是我从以前的一个应用上直接拷贝过来的.以前使用的腾讯的邮件服务,程序执行起来没有任何问题.后来修改为微软office365邮件服务后,却遇到了两个问题. 问题一,tls加密设置 异常信息如下: 复制代码 代码如下: Exception in thread "main" com.sun.mail.smtp.SMTPSendFailedException: 530 5.7.57 SMTP; Client was not authenticated to send anonym

用java实现邮件发送验证码

java实现邮件发送验证码 网易邮箱开通POP3SMTP服务的步骤 java实现邮件发送验证码 建议不要用qq邮箱,我使用qq邮箱直接一直给我报530错误,我一直认为我代码写的有错误或者POP3/SMTP服务没弄好.所以建议注册个别的邮箱,我就申请了个网易163邮箱瞬间就好了.所以去申请个别的邮箱吧. 用邮件发送验证码,首先需要jar包.我写的代码只需要mail.jar,没有的话可以给我留言,我给你发个. 废话不说了直接上代码(这个代码就是个工具类直接用就好) package com.ithei

java问题-java实现验证发送邮箱功能(如何给指定邮箱发送验证信息)

问题描述 java实现验证发送邮箱功能(如何给指定邮箱发送验证信息) package org.ouyang.servlet; import java.io.IOException; import java.io.PrintWriter; import java.util.Date; import java.util.Properties; import javax.mail.Message; import javax.mail.MessagingException; import javax.m

线程-java server端发送数据给客户端出现问题,求高手帮忙看下!

问题描述 java server端发送数据给客户端出现问题,求高手帮忙看下! java server端发送数据给客户端出现问题,求高手帮忙看下! package com.zeph.multiclient; import java.io.*; import java.net.ServerSocket; import java.net.Socket; public class MultiThreadServer extends Thread { private Socket client; publ

java如何设置发送短信的节点,如:找回密码、更换手机/邮箱的节点

问题描述 java如何设置发送短信的节点,如:找回密码.更换手机/邮箱的节点 jva如何设置发送短信的节点,如:找回密码.更换手机/邮箱的节点 解决方案 和java没有关系,直接把这些写在你的找回密码.更换邮箱等功能里面就可以了. 解决方案二: 首先这个收发短信,你可以买短信猫类似的,会提供接口给你直接调用. 更换节点/邮箱的话你应该把以前的数据 更新就可以.

Java HtmlEmail 邮件发送的简单实现代码_java

Java 项目中常常回遇到发送邮件 Java 发送邮件有几种,今天先给大家介绍用 HtmlEmail 来发送邮件,我这里是用 Maven 来搭建的 HtmlEmail 可以抄带HTML 首先 需要导入jar 包 <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-email</artifactId> <version>1.4</versio

java中javamail发送带附件的邮件实现方法_java

本文实例讲述了java中javamail发送带附件的邮件实现方法.分享给大家供大家参考.具体分析如下: JavaMail,顾名思义,提供给开发者处理电子邮件相关的编程接口.它是Sun发布的用来处理email的API.它可以方便地执行一些常用的邮件传输,JavaMail是可选包,因此如果需要使用的话你需要首先从java官网上下载.目前最新版本是JavaMail1.5.0,下面我们来看看javamail发送带附件的邮件实例 mail.java 代码: 复制代码 代码如下: package mail;

Java事件处理模式

Java的事件模式是动态响应系统重要的基础,在图形界面领域的事件模式已经有很多文章介绍,但是在服务器端我们会碰到更多的事件模式,这里本人试图总结一下: 事件直接驱动模式 事件模式的第一个要求就是性能的要求,需要直接而且快,Command模式是必须经常使用的,主要适合于迅速处理 前台的命令,Command模式往往是系统架构的重要部分,也是流程控制的主要模式. Command模式经常Java的Reflect一起使用,因为系统的事件处理系统是处于动态变化的,随着功能要求扩展,就可能有动态变化事件处理响