Java事件处理机制:EventObject类作为描述事件信息的事件信息类的基类,由EventListener接口派生新的接口或类来作为事件接收方的类,再定义事件源类

事件信息类构造方法必须含有事件源参数和事件信息字符串;事件接收方事件处理方法必须含有事件信息对象作为参数;事件源类负责事件接收方的注册取消注册事件触发通知事件接收方处理事件。                嘿嘿,如有转载,请声明http://www.cnblogs.com/jinmoon/;       

本实例是火灾报警后火警和学生的事件处理

import java.util.EventListener;
import java.util.EventObject;
import java.util.Scanner;

public class Test {
public static void main(String[] args) {
HuoJin t = new HuoJin();
JiaRe s = new JiaRe();
Student a=new Student();
a.addStudent(s);
s.addPeople(a);
t.addStudent(s);
s.addTeacher(t);
s.Ask();
}
}
//火警
class HuoJin implements Q_or_A_Listener{
JiaRe s = null;

public void addStudent(JiaRe s) {
if (this.s == null)
this.s = s;                                           //注册,
}
public void removeStudent(JiaRe s) {
if (this.s == null)
return;                                  //取消注册
this.s = null;
}
public void Q_or_A_Event(Q_or_A q){//处理事件,回答问题
System.out.println("火警   灭火");
/* String a;
int i = Integer.valueOf(q.getQ_or_A()).intValue();
System.out.println(q.getQ_or_A());
if(i>80){
a = "HuoJin 灭火"; 
}
else{
a = "HuoJin 工作";
}

if (this.s == null){
System.out.println("没有注册!");
return;
}            //没有注册监视器,不触发事件。
Q_or_A event = new Q_or_A(this, a); //创建事件对象
Notify(event); */                          //通知火警
}
private void Notify(Q_or_A event){
this.s.Q_or_A_Event(event);              //调用学生的事件处理方法,传递事件对象
}

}
//学生
class Student implements Q_or_A_Listener{
JiaRe s = null;

public void addStudent(JiaRe s) {
if (this.s == null)
this.s = s;                                   //注册
}
public void removeStudent(JiaRe s) {
if (this.s == null)
return; //从未注册过,不用取消。
this.s = null;
}
public void Q_or_A_Event(Q_or_A q){//处理事件,回答问题
System.out.println("学生   逃跑");
/* String a;
// System.out.println(q.getQ_or_A());
int i = Integer.valueOf(q.getQ_or_A()).intValue();
if(i>80){
a = "Student 逃跑"; 
}
else{
a = "Student 学习";
}

if (this.s == null){
System.out.println("没有注册!");
return;
} //没有注册监视器,不触发事件。
Q_or_A event = new Q_or_A(this, a); //创建事件对象
Notify(event); */ //通知学生
}
private void Notify(Q_or_A event){
this.s.Q_or_A_Event(event); //调用学生的事件处理方法,传递事件对象
}

}
//加热器类
class JiaRe implements Q_or_A_Listener{
HuoJin t = null;
Student b = null;

public void addTeacher(HuoJin t) {
if (this.t == null)
this.t = t; //申请火警
}
public void addPeople(Student t) {
if (this.t == null)
this.b = t; //申请学生
}
public void removeTeacher(HuoJin t) {
if (this.t == null)
return; //从未注册过,不用取消
this.t = null;
}
public void removePeople(Student t) {
if (this.b == null)
return; //从未注册过,不用取消
this.b = null;
}
protected void Ask() {
if (t == null)
return; //没有注册火警,不提问
String s = String.valueOf(WenDu());    //字符串转换成整形
int i = Integer.valueOf(s).intValue();      //整形转换成字符
Q_or_A event = new Q_or_A(this, s); //构造函数事件初始化
if(i>80){
System.out.println(s);
Notify(event); //处理事件,通知监视器,即接收者
} /
else{
System.out.println(s);
System.out.println("安全");
}

}
public int WenDu()
{
Scanner scanner=new Scanner(System.in);
int wendu=(int)(Math.random()*100);
return wendu;
}
private void Notify(Q_or_A event){
this.t.Q_or_A_Event(event);
this.b.Q_or_A_Event(event);
//调用火警,学生,的事件处理方法,传递事件对象
}
public void Q_or_A_Event(Q_or_A a){ //事件处理方法,接收答案
System.out.println(a.getQ_or_A());
}
}
//接口
interface Q_or_A_Listener extends EventListener { //意义就在于告诉所有的调用者,我是一个监听器。
public void Q_or_A_Event(Q_or_A event);
}
//事件信息类
class Q_or_A extends EventObject{//定义事件状态类,或称为事件信息类。用于描述事件信息
private String Q_or_A = "";

public Q_or_A( Object source, String doorState ) { //明确事件源和事件信息
super(source); // 它封装了父类EventObject的getSource方法,得到的就是事件源。
this.Q_or_A = doorState;
}

public void setQ_or_A( String doorState ) {
this.Q_or_A = doorState;
}

public String getQ_or_A() { //返回的就是事件源(即教师、即被观察者),
return this.Q_or_A;
}

}

java 事件处理的更多相关文章

  1. 从零开始理解JAVA事件处理机制(1)

    “事件”这个词已经被滥用了.正因为“事件”的被滥用,很多人在用到事件的时候不求甚解,依样画葫芦,导致学习工作了很多年,还是不清楚什么是事件处理器.什么是事件持有者.所以,如果你对于Event这个词还是 ...

  2. 从零开始理解JAVA事件处理机制(2)

    第一节中的示例过于简单<从零开始理解JAVA事件处理机制(1)>,简单到让大家觉得这样的代码简直毫无用处.但是没办法,我们要继续写这毫无用处的代码,然后引出下一阶段真正有益的代码. 一:事 ...

  3. 从零开始理解JAVA事件处理机制(3)

    我们连续写了两小节的教师-学生的例子,必然觉得无聊死了,这样的例子我们就是玩上100遍,还是不知道该怎么写真实的代码.那从本节开始,我们开始往真实代码上面去靠拢. 事件最容易理解的例子是鼠标事件:我们 ...

  4. java事件处理机制

    java中的事件机制的参与者有3种角色:   1.event object:就是事件产生时具体的"事件",用于listener的相应的方法之中,作为参数,一般存在与listerne ...

  5. [转]Java事件处理机制- 事件监听器的四种实现方式

    原文来自http://stefan321.iteye.com/blog/345221 自身类作为事件监听器 外部类作为事件监听器 匿名内部类作为事件监听器 内部类作为事件监听器 自身类作为事件监听器: ...

  6. Java事件处理机制(深入理解)

    本文是关于Java事件处理机制的梳理,以及有重点的介绍一些注意点,至于基础的概念啥的不多赘述. 一.Java事件处理机制初步介绍(看图理解) 根据下图,结合生活实际,可以得知监护人可以有多个,坏人对小 ...

  7. Java事件处理机制- 事件监听器的四种实现方式

    自身类作为事件监听器 外部类作为事件监听器 匿名内部类作为事件监听器 内部类作为事件监听器 自身类作为事件监听器: import javax.swing.*; import java.awt.*; i ...

  8. java 事件处理机制:按下上下左右键控制小球的运动

    /** * 加深对事件处理机制的理解 * 通过上下左右键来控制一个小球的位置 */package com.test3;import java.awt.*;import javax.swing.*;im ...

  9. java事件处理机制(自定义事件)

    java中的事件机制的参与者有3种角色: 1.event object:事件状态对象,用于listener的相应的方法之中,作为参数,一般存在与listerner的方法之中 2.event sourc ...

随机推荐

  1. Nodejs MSSQL详细解读

    MSSQL 是Nodejs用于连接Microsoft SQL Server 的插件. 安装方法 npm install mssql 配置Config const config = { user: '. ...

  2. hadoop2集群中关键配置文件的记录

    配置HDFS  高可用 1.配置HDFS配置文件 $ vi hdfs-site.xml #写入 <configuration> #配置NameService 名字随便起 <prope ...

  3. 关于Makefile,Makefile.in,Makefile.am,Configure功能及相互关系的问题

    makefile写法 在 Unix 上写程式的人大概都碰过 Makefile,尤其是用 C 来开发程式的人.用 make来开发和编译程式的确很方便,可是要写出一个 Makefile就不简单了.偏偏介绍 ...

  4. Leetcode题解(八)

    26.Remove Duplicates from Sorted Array 题目 直接上代码,方法很简单: class Solution { public: int removeDuplicates ...

  5. jQuery选择器(基本过滤选择器)第三节

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/stri ...

  6. 应用在安卓和ios端APP的证件识别

    移动端证件识别智能图文处理,是利用OCR识别技术,通过手机拍摄身份证图像或者从手机相册中加载证件图像,过滤身份证的背景底纹干扰,自动分析证件各文字进行字符切分.识别,最后将识别结果按姓名.地址.民族. ...

  7. 通过geotools读写shp文件

    依赖jar包 读取shp public static void main(String[] path) { DbaseFileReader reader = null; try { reader = ...

  8. 《项目架构那点儿事》——快速构建Junit用例

    [前 言]按照惯例,在实际项目中我往往会对自己编写的程序进行测试,当测试通过后才能将其用于实战中,当然,编写单元测试是不可避免的,可以直接清晰的检验出 我们程序的可靠性.可只执行性,从中发现问题从而得 ...

  9. 【scikit-learn 0.19 中文文档 】安装 scikit-learn | ApacheCN

    中文文档: http://sklearn.apachecn.org/cn/0.19.0/tutorial/basic/tutorial.html 英文文档: http://sklearn.apache ...

  10. 利用docker搭建spark hadoop workbench

    目的 用docker实现所有服务 在spark-notebook中编写Scala代码,实时提交到spark集群中运行 在HDFS中存储数据文件,spark-notebook中直接读取 组件 Spark ...