成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Java基礎教程之事件和監聽器

開發 后端
本文介紹了事件監聽器的設計方法。事件監聽器是經常可以遇到的一種設計模式,即:當模塊的一部分A在完成后需要通知其他的軟件模塊B,而等待通知的模塊B在事先不需要采用輪詢的方式來查看另一個模塊A是否通知自己。

事件監聽器是經常可以遇到的一種設計模式,一般用在這樣一種場景下:當模塊的一部分A在完成后需要通知其他的軟件模塊B,而等待通知的模塊B在事先不需要采用輪詢的方式來查看另一個模塊A是否通知自己。即,當某事件發生,則監聽器立刻就知道了該事件。這種模式大量的應用在GUI設計中,比如按鈕的點擊,狀態欄上狀態的改變等等。

接口的設計

我們需要一個對事件(event)的抽象,同樣需要一個對監聽器(listener)的抽象。我們可以把接口抽的很簡單:

這個是事件源的接口,只需要提供一個可以獲取事件類型的方法即可:

  1. package listenerdemo.framework;  
  2.  
  3. /**  
  4.  * @author juntao.qiu  
  5.  */ 
  6. public interface EventListener {  
  7.     /**  
  8.      * handle the event when it raise  
  9.      * @param event  
  10.      */ 
  11.     public void handleEvent(EventSource event);  
  12. }  
  13.    

監聽器接口,提供一個當事件發生后的處理方法即可:

  1. package listenerdemo.framework;  
  2.  
  3. public interface EventSource {  
  4.     public final int EVENT_TIMEOUT = 1;  
  5.     public final int EVENT_OVERFLOW = 2;  
  6.  
  7.     /**  
  8.      * get an integer to identify a special event  
  9.      * @return  
  10.      */ 
  11.     public int getEventType();  
  12. }  

實例化事件

我們舉一個實現了事件源接口(EventSource)的類TimeoutEvent 來說明如何使用事件監聽器模型:

  1. package listenerdemo;  
  2.  
  3. import listenerdemo.framework.*;  
  4.  
  5. public class TimeOutEvent implements EventSource{  
  6.     private int type;  
  7.  
  8.     public TimeOutEvent(){  
  9.         this.type = EventSource.EVENT_TIMEOUT;;  
  10.     }  
  11.       
  12.     public int getEventType() {  
  13.         return this.type;  
  14.     }  
  15.  
  16. }  

這個事件的類型為EVENT_TIMEOUT, 當操作超時時觸發該事件,我們假設這樣一個場景:一個定時器T, 先設置這個定時器的時間為t,當t到時后,則觸發一個超時事件,當然,事件是需要監聽器來監聽才有意義的。我們看看這個定時器的實現:

  1. package listenerdemo;  
  2.  
  3. import listenerdemo.framework.*;  
  4.  
  5. /**  
  6.  * @author juntao.qiu  
  7.  */ 
  8. public class Timer extends Thread{  
  9.     private EventListener listener;  
  10.     private int sleepSeconds;  
  11.  
  12.     public Timer(int seconds){  
  13.         this.sleepSeconds = seconds;  
  14.     }  
  15.  
  16.     public void setEventListener(EventListener listener){  
  17.         this.listener = listener;  
  18.     }  
  19.       
  20.     public void run(){  
  21.         for(int i = sleepSeconds;i>0;i--){  
  22.             try {  
  23.                 Thread.sleep(1000);  
  24.             } catch (InterruptedException ex) {  
  25.                 System.err.println(ex.getMessage());  
  26.             }  
  27.         }  
  28.           
  29.         raiseTimeoutEvent();//raise一個TimeOut事件給監聽器  
  30.     }  
  31.  
  32.     private void raiseTimeoutEvent(){  
  33.         this.listener.handleEvent(new TimeOutEvent());  
  34.     }  
  35. }  

使用事件及其監聽器

在類Tester的execute()方法中,我們先設置一個定時器,這個定時器初始化為3秒,設置好定時器后,程序進入一個while(true)循環中,當定時器到時后,它會發送一個timeout事件給當前線程Tester,此時我們可以設置execute中的while條件為false,退出死循環。流程很清晰了,我們來看看代碼:

  1. package listenerdemo;  
  2.  
  3. import listenerdemo.framework.*;  
  4.  
  5. /**  
  6.  * @author juntao.qiu  
  7.  */ 
  8. public class EventListenerTester implements EventListener{  
  9.     private boolean loop = true;  
  10.  
  11.     public void execute(){  
  12.         Timer timer = new Timer(3);//初始化一個定時器  
  13.         timer.setEventListener(this);//設置本類為監聽器  
  14.         timer.start();  
  15.           
  16.         while(loop){  
  17.             try{  
  18.                 Thread.sleep(1000);  
  19.                 System.out.println("still in while(true) loop");  
  20.             }catch(Exception e){  
  21.                 System.err.println(e.getMessage());  
  22.             }  
  23.         }  
  24.  
  25.         System.out.println("interupted by time out event");  
  26.     }  
  27.  
  28.  
  29. //實現了EventListener接口  
  30.     public void handleEvent(EventSource event) {  
  31.         int eType = event.getEventType();  
  32.         switch(eType){//判斷事件類型,我們可以有很多種的事件  
  33.             case EventSource.EVENT_TIMEOUT:  
  34.                 this.loop = false;  
  35.                 break;  
  36.             case EventSource.EVENT_OVERFLOW:  
  37.                 break;  
  38.             default:  
  39.                 this.loop = true;  
  40.                 break;  
  41.         }  
  42.     }  
  43.  
  44.     public static void main(String[] args){  
  45.         EventListenerTester tester = new EventListenerTester();  
  46.         tester.execute();  
  47.     }  
  48.  
  49. }  

運行結果如下:
run:
still in while(true) loop
still in while(true) loop
still in while(true) loop
interupted by time out event
程序正是按照預期的方式運行了,當然,為了說明主要問題,我們的事件,對事件的處理,監聽器的接口都盡可能的保持簡單。如果想要完成更復雜的功能,可以參考文章中的方法自行擴充,但是大概流程文中都已經說到。

【編輯推薦】

  1. Java類中域和方法設置中的常見錯誤
  2. Java類體中的this和super的用法
  3. Java通過JNI調用C語言的方法
  4. Java連接MySQL中文亂碼處理
  5. 淺析Java虛擬機的工作流程
責任編輯:yangsai 來源: 博客園
相關推薦

2017-07-18 10:14:23

OracleMerge into教程

2016-08-31 14:01:31

MySQL存儲數據庫

2009-07-17 09:55:02

事件監聽器SWT和SwingAWT

2010-08-09 09:47:34

Flex事件機制

2020-12-15 10:46:29

事件監聽器Spring Boot

2012-02-03 13:27:16

2010-08-09 11:06:01

Flex事件機制

2021-07-08 07:52:49

容器監聽器Event

2011-04-25 09:22:44

C#事件

2021-07-16 07:21:45

C++可調用對象std::functi

2009-07-24 09:20:15

數組實例

2023-11-01 07:55:03

事件監聽器傳遞數據

2011-03-21 16:21:49

Oracle監聽口令監聽器

2011-04-26 08:56:31

C#

2011-07-21 10:17:53

java

2021-02-06 07:49:48

C語言編程開發技術

2011-04-15 09:20:56

ASP.NET MVC

2009-07-08 17:39:23

Servlet監聽器

2009-09-27 17:46:22

Hibernate監聽

2010-01-13 09:49:09

注釋監聽器Listener
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美无乱码久久久免费午夜一区 | 能看的av | 国产精品亚洲一区 | 精品无码久久久久国产 | 99久久国产综合精品麻豆 | 欧美亚洲第一区 | 亚洲欧美日韩精品久久亚洲区 | 亚洲欧洲色视频 | 99视频在线免费观看 | 一区二区三区四区不卡 | 国产蜜臀97一区二区三区 | 免费在线成人网 | 精品影院 | 国产电影一区二区在线观看 | 国产精品综合一区二区 | 精品一区二区三区在线观看 | 欧美人成在线视频 | 99九九视频| 玖玖操| 一区二区三区回区在观看免费视频 | 国产成人免费网站 | 日韩久久精品 | 日韩精品一区二区三区中文在线 | 亚洲精品一区二三区不卡 | 久久成人免费视频 | 成人影院在线 | 欧美成人一区二区 | 中文字幕国产日韩 | 欧美日韩一区二区三区四区 | 日本免费在线 | 欧美国产中文字幕 | 精品久久久久久久人人人人传媒 | 午夜电影在线播放 | 久久国产精品久久久久久久久久 | 日韩国产高清在线观看 | 久久精品久久久久久 | 欧美日韩综合 | 男人的天堂中文字幕 | 91久久精品国产免费一区 | 91精品国产91久久久久久密臀 | 久久久久国产一区二区三区四区 |