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

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

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

    隨筆 - 11, 文章 - 1, 評論 - 20, 引用 - 0
    數(shù)據(jù)加載中……

    基于事件分發(fā)機制的企業(yè)應用開發(fā)

        做過DOS編程的人都知道,Dos編程和Window編程最大不同之一就是事件機制的編程,普遍的,目前事件機制的使用已經在Windows下的應用程序中遍地開花了,可是基于事件傳播的應用僅僅限于window應用程序嗎?答案是:不。
        在IOC概念的不斷沖擊下,我們需要回頭去審視前兩年自己開發(fā)的,心中為之驕傲的,認為非常優(yōu)秀的程序,在這過程中,我們就會看到這些驕傲在最新的概念沖擊下煙消云散了。變成了丑陋的,緊耦合的反面范例。讓我們來看看以下場景:

     某公司有基于某平臺的兩子系統(tǒng),訂購系統(tǒng)A和財務系統(tǒng)B。當采購員在預采購某物品前,先在定購系統(tǒng)A中登記需要購買的貨物和價格,然后財務系統(tǒng)B就開始該筆購物款項的申請流程。
     首先讓我們來看看兩年前的代碼是怎么實現(xiàn)的:

     

    public class OrderService {
       
    private FinancialService  financialService=new FinancialServiceImpl();
         
    public Order saveOrder(Order order){
      。。。。處理訂單
                    financialService.createRequestOfMoney(order.getAmount());
       }

     }


    從上面的代碼中可以很明顯看到,定購系統(tǒng)A和財務子系統(tǒng)發(fā)生了耦合,也許有同志說,那我采用Spring等IOC框架來解耦:
     

    public class OrderService {
       
    private FinancialService  financialService;
       
    public void setFinancialService(FinancialService fs){
         
    this.financialService=fs;
       }

         
    public Order saveOrder(Order order){
      。。。。處理訂單
                    financialService.createRequestOfMoney(order.getAmount());
       }

     }


    財務子系統(tǒng)B的實現(xiàn)FinancialServiceImpl是通過Spring等IOC框架設置進去的。這樣不是很完美了嗎?

    但是我仍然要說,這個只是五十步笑百步罷了。再請看以下場景:該公司的業(yè)務規(guī)則起了變化,金額少于1萬元的定購不需要通過財務申請流程。這樣財務子系統(tǒng)B升級到B2了,多了一個直接撥款的API payMoney()。這時候,定購系統(tǒng)該怎么辦?除了修改代碼沒有別的辦法。這個時候,基于事件分發(fā)處理的機制就大派用場了。
      修改原來的訂單系統(tǒng)實現(xiàn)下單消息的廣播。
     

    public class OrderService extend EventBrocast{
       
    private FinancialService  financialService=new FinancialServiceImpl();
         
    public Order saveOrder(Order order){
      。。。。處理訂單
                    brocastEvent(
    new Event(order)); // ***
       }

     }

     

     實現(xiàn)一個消息監(jiān)聽器:

    public OrderEventListener implements EventListener{
      
    public void performed(Event e){
       Order order 
    =(Order) e.getObject();
        financialService.createRequestOfMoney(order.getAmount());
      }

     }

     

     在配置中設置(這里我們使用的是Spring)
     <bean id="orderService" ...>
      <property name="eventListener">
       <list>
        <ref local="orderListener"/>
       </list>
      </property>
     </bean>
     <bean id="orderListener" ...>

     這樣我們就實現(xiàn)了訂單系統(tǒng)和財務系統(tǒng)的解耦,如果財務系統(tǒng)發(fā)生的修改,我們就只需實現(xiàn)新的監(jiān)聽器就可以了:

     

    public  NewOrderEventListener implements EventListener{
        
    private FinancialService  financialService;
        
    public void setFinancialService(FinancialService fs){
         
    this.financialService=fs;
       }


      
    public void performed(Event e){
       Order order 
    =(Order) e.getObject();
        financialService.payMoney(order.getAmount());
      }

     }

     

     下一篇文章,我將引入AOP的概念來將系統(tǒng)提高到更高的抽象層次。
     (全文完)

    posted on 2005-12-05 20:31 wolfsquare 閱讀(2306) 評論(4)  編輯  收藏 所屬分類: 企業(yè)應用

    評論

    # re: 基于事件分發(fā)機制的企業(yè)應用開發(fā)   回復  更多評論   

    我說一下我的一小點看法

    對于你的代碼
    public class OrderService {
    private FinancialService financialService;
    public void setFinancialService(FinancialService fs){
    this.financialService=fs;
    }
    public Order saveOrder(Order order){
    。。。。處理訂單
    // financialService.createRequestOfMoney(order.getAmount());
    financialService.dealWith(order.getAmount());
    }
    }

    我覺得當遇到你說的情況時,我同樣可以Create another impl class來完成這個任務阿
    當然FinancialService 的接口最好更改為dealWithMoney(...)

    public class NewFinancialService implements FinancialService
    {
    dealWithMoney(...)
    {
    payMoney(...)
    }
    }

    在這個子類中完成任務。然后注入到OrderService阿
    2005-12-06 10:03 | 小明

    # re: 基于事件分發(fā)機制的企業(yè)應用開發(fā)   回復  更多評論   

    如果FinancialService 不幸的被聲明為了final.
    如果又來了一個新子系統(tǒng)貨運子系統(tǒng)C或者更多目前還未知的子系統(tǒng)需要通知訂單通知..
    還有很多如果如果...
    2005-12-06 11:32 | wolfsquare

    # re: 基于事件分發(fā)機制的企業(yè)應用開發(fā)   回復  更多評論   

    如果FinancialService 不幸的被聲明為了final. ?

    難道FinancialService 不是接口么?
    2005-12-06 11:55 | 小明

    # re: 基于事件分發(fā)機制的企業(yè)應用開發(fā)   回復  更多評論   

    我沒怎么看懂,還要學習呀,以后說得詳細些,哈哈
    2007-03-08 16:53 | cljspn
    主站蜘蛛池模板: 国产亚洲情侣一区二区无| 在线观看日本免费a∨视频| 夜色阁亚洲一区二区三区| 亚洲日韩av无码中文| 中文字幕免费在线看线人| 亚洲精品视频在线| 一区二区三区观看免费中文视频在线播放 | 久久久亚洲精品视频| 精品亚洲永久免费精品 | 综合在线免费视频| 亚洲大成色www永久网址| 99re热免费精品视频观看| 亚洲综合偷自成人网第页色 | 亚洲日本韩国在线| 国产免费网站看v片在线| 亚洲自偷自偷精品| 亚洲精品动漫免费二区| 亚洲欧美综合精品成人导航| 国产午夜影视大全免费观看 | 亚洲成A∨人片在线观看无码| 黄页网站在线观看免费高清| 亚洲欧美成人av在线观看| 免费在线观看a级毛片| 黄桃AV无码免费一区二区三区| 亚洲国产精品一区二区久久hs| 永久在线观看www免费视频| 亚洲欧美自偷自拍另类视| 久久久久亚洲AV无码专区桃色| 久久久久久国产精品免费免费男同| 亚洲影视一区二区| 免费观看日本污污ww网站一区| a级毛片免费全部播放| 亚洲人成电影青青在线播放| 免费观看四虎精品国产永久| 野花香高清在线观看视频播放免费| 中文字幕亚洲综合小综合在线| 亚洲国产精品成人久久蜜臀| 99re热精品视频国产免费| 国产精品无码亚洲一区二区三区| 亚洲免费观看视频| 免费看片免费播放|