<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    javaGrowing

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      92 隨筆 :: 33 文章 :: 49 評論 :: 0 Trackbacks

    Java與C#的事件處理都是實現了事件源-事件響應者機制,但又不完全相同。Java實現的是一種事件源與事件響應者兩級實體對象方式,這里的事件響應者也是事件監聽者,而C#實現的是一種事件源-代理-事件響應者三級實體對象方式。下面就這兩種方式來具體說明。

    Java事件處理
    ?
    ?
    從概念上講,事件是一種在“源對象”和“監聽者對象”之間,某種狀態發生變化的傳遞機制。事件有許多不同的用途,例如在Windows系統中常要處理的鼠標事件、窗口邊界改變事件、鍵盤事件等。在Java中則是定義了一個一般的、可擴充的事件機制,這種機制能夠:

    · 對事件類型和傳遞的模型的定義和擴充提供一個公共框架,并適合于廣泛的應用。

    · 與Java語言和環境有較高的集成度。

    · 事件能被描述環境捕獲和觸發。

    · 能使其它構造工具采取某種技術在設計時直接控制事件,以及事件源和事件監聽者之間的聯系。

    · 事件機制本身不依賴于復雜的開發工具。

    · 事件從事件源到監聽者的傳遞是通過對目標監聽者對象的Java方法調用進行的。對每個明確的事件的發生,都相應地定義一個明確的Java方法。這些方法都集中定義在事件監聽者(EventListener)接口中,這個接口要繼承java.util.EventListener。實現了事件監聽者接口中一些或全部方法的類就是事件監聽者。伴隨著事件的發生,相應的狀態通常都封裝在事件狀態對象中,該對象必須繼承自 java.util.EventObject。事件狀態對象作為單參傳遞給應響應該事件的監聽者方法中。發出某種特定事件的事件源的標識是:遵從規定的設計格式為事件監聽者定義注冊方法,并接受對指定事件監聽者接口實例的引用。

    有時,事件監聽者不能直接實現事件監聽者接口,或者還有其它的額外動作時,就要在一個源與其它一個或多個監聽者之間插入一個事件適配器類的實例,來建立它們之間的聯系。

    事件狀態對象(Event State Object)


    與事件發生有關的狀態信息一般都封裝在一個事件狀態對象中,這種對象是java.util.EventObject的子類。按設計習慣,這種事件狀態對象類的名應以Event結尾。例如:

    ?

    public class MouseMovedExampleEvent extends java.util.EventObject
    { protected int x, y;
    /* 創建一個鼠標移動事件MouseMovedExampleEvent */
     MouseMovedExampleEvent(java.awt.Component source, Point location) {
    super(source);
    x = location.x;
    y = location.y;
    }
    /* 獲取鼠標位置*/
    public Point getLocation() {
    return new Point(x, y);
    }}


    事件監聽者接口(EventListener Interface)與事件監聽者



    由于Java事件模型是基于方法調用,因而需要一個定義并組織事件操縱方法的方式。事件操縱方法都被定義在繼承了 java.util.EventListener類的EventListener接口中,按規定,EventListener接口的命名要以 Listener結尾。任何一個類如果想操縱在EventListener接口中定義的方法都必須以實現這個接口方式進行。這個類也就是事件監聽者。例如:
    /*先定義了一個鼠標移動事件對象*/
      public class MouseMovedExampleEvent extends java.util.EventObject {
       // 在此類中包含了與鼠標移動事件有關的狀態信息
         ...
      }
      /*定義了鼠標移動事件的監聽者接口*/
      interface MouseMovedExampleListener extends java.util.EventListener {
    /*在這個接口中定義了鼠標移動事件監聽者所應支持的方法*/
    void mouseMoved(MouseMovedExampleEvent mme);
    }

    class ArbitraryObject implements MouseMovedExampleListener {
       public void mouseMoved(MouseMovedExampleEvent mme)
      { ... }

    ArbitraryObject就是MouseMovedExampleEvent事件的監聽者。

    事件監聽者的注冊與注銷



    為了各種可能的事件監聽者把自己注冊入合適的事件源中,建立源與事件監聽者間的事件流,事件源必須為事件監聽者提供注冊和注銷的方法。在前面的bound屬性介紹中已看到了這種使用過程,在實際中,事件監聽者的注冊和注銷要使用標準的設計格式:
    public void add< ListenerType>(< ListenerType> listener);
    public void remove< ListenerType>(< ListenerType> listener);

    例如,首先定義了一個事件監聽者接口:

    public interface ModelChangedListener extends java.util.EventListener {
    void modelChanged(EventObject e);
    }

    接著定義事件源類

    public abstract class Model {
    private Vector listeners = new Vector(); // 定義了一個儲存事件監聽者的數組
    /*上面設計格式中的< ListenerType>在此處即是下面的ModelChangedListener*/
    public synchronized void addModelChangedListener(ModelChangedListener mcl)
      { listeners.addElement(mcl); }//把監聽者注冊入listeners數組中
    public synchronized void removeModelChangedListener(ModelChangedListener mcl)
        { listeners.removeElement(mcl); //把監聽者從listeners中注銷
        }
    /*以上兩個方法的前面均冠以synchronized,是因為運行在多線程環境時,可能同時有幾個對象同時要進行
    注冊和注銷操作,使用synchronized來確保它們之間的同步。開發工具或程序員使用這兩個方法建立源與監
    聽者之間的事件流*/
     protected void notifyModelChanged()
    {/**事件源使用本方法通知監聽者發生了modelChanged事件*/
        Vector l;
        EventObject e = new EventObject(this);
        /*首先要把監聽者拷貝到l數組中,凍結EventListeners的狀態以傳遞事件。這樣來確保在事件
    傳遞到所有監聽者之前,已接收了事件的目標監聽者的對應方法暫不生效。*/
        synchronized(this) {
          l = (Vector)listeners.clone();
        }
        for (int i = 0; i < l.size(); i++) {
         /* 依次通知注冊在監聽者隊列中的每個監聽者發生了modelChanged事件,
         并把事件狀態對象e作為參數傳遞給監聽者隊列中的每個監聽者*/
    ((ModelChangedListener)l.elementAt(i)).modelChanged(e);
        }
        }
       }

    在程序中可見事件源Model類顯式地調用了接口中的modelChanged方法,實際是把事件狀態對象e作為參數,傳遞給了監聽者類中的modelChanged方法。

    posted on 2006-09-28 10:22 javaGrowing 閱讀(328) 評論(1)  編輯  收藏 所屬分類: java學習

    評論

    # re: 淺談Java與C#的事件處理機制(1) 2006-11-22 09:17 businesscardsshop
    best site
    http://www.businesscardsshop.com/  回復  更多評論
      

    主站蜘蛛池模板: 在线亚洲精品福利网址导航| 亚洲中文字幕无码一区| 亚洲综合小说久久另类区| 久草视频在线免费看| 久久亚洲精品成人av无码网站| 精品成人免费自拍视频| 亚洲国产精品久久久久婷婷软件| 一级毛片免费不卡在线| 亚洲高清中文字幕| 亚洲免费观看在线视频| 亚洲第一成人在线| 国产精品久久免费视频| 午夜在线免费视频| 亚洲人成无码网站| 84pao强力永久免费高清 | 午夜一级毛片免费视频| 亚洲成AV人片在WWW| 亚洲精品乱码久久久久久不卡| 国产免费福利体检区久久| 亚洲gv白嫩小受在线观看| 1000部拍拍拍18勿入免费视频软件| 亚洲精品在线不卡| 日韩电影免费在线| 国产免费区在线观看十分钟| 亚洲一卡2卡三卡4卡有限公司| 精品久久久久成人码免费动漫| 国产精品久久久久久亚洲小说| 亚洲色精品vr一区二区三区| 3344免费播放观看视频| 亚洲大尺度无码无码专线一区| 亚洲国产精品一区二区九九| 性xxxxx大片免费视频| 亚洲午夜无码久久久久软件| 亚洲国产激情一区二区三区| 久久国产高潮流白浆免费观看| 中文字幕无码亚洲欧洲日韩| 国产亚洲日韩在线三区| 最近高清国语中文在线观看免费| 中文毛片无遮挡高清免费| 精品久久亚洲中文无码| 久久青青草原亚洲av无码|