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

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

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

    常言笑的家

    Spring, Hibernate, Struts, Ajax, RoR

    控制反轉,依賴注入,好萊塢原則

    IoC 或者 DI 或者 …一大堆的縮寫詞
    依賴注入和控制反轉其實是同一回事,依賴注入最典型的應用就是控制反轉

    不管是面向對象,還是面向過程,都需要分成許多的塊,然后由這些部件協同工作完成任務
    要協同工作就會產生依賴,一個方法調用另一個方法,一個對象包含另一個對象
    如果對象A包含對象B的話,就需要在A里new一個B
    依賴注入從具體類B里抽象出接口IB——IB的具體實現可能有很多B,B1,B2…很多種——這樣A可以不用再new具體的B了,而是跟IoC容器說:我要一個IB(getBean("IB"))。然后,由容器根據配置文件來做具體的new的工作。具體new的是哪個,由配置文件從代碼外部決定,要更換成B,B1,或是B2…修改配置文件就能做到,不用再改代碼了

    例:
    假設你編寫了兩個類,一個是人(Person),一個是手機(Mobile)。
    人有時候需要用手機打電話,需要用到手機的dialUp方法。
    傳統的寫法是這樣:

    //code
    public class Person
        
    public boolean makeCall(long number)
            Mobile mobile
    =new Mobile(); 
            
    return mobile.dialUp(number); 
        }
     
    }

    也就是說,類Person的makeCall方法對Mobile類具有依賴,必須手動生成一個新的實例new Mobile()才可以進行之后的工作。
    依賴注入的思想是這樣,當一個類(Person)對另一個類(Mobile)有依賴時,不再該類(Person)內部對依賴的類(Moblile)進行實例化,而是之前配置一個beans.xml,告訴容器所依賴的類(Mobile),在實例化該類(Person)時,容器自動注入一個所依賴的類(Mobile)的實例。
    接口
    //code
    public Interface MobileInterface
        
    public boolean dialUp(long number);
    }


    Person類:
    //code
    public class Person{
        
    private MobileInterface mobileInterface;
        
    public boolean makeCall(long number){
            
    return this.mobileInterface.dialUp(number);
        }

        
    public void setMobileInterface(MobileInterface mobileInterface){
            
    this.mobileInterface=mobileInterface;
        }

    }


    在xml文件中配置依賴關系
    //code
    <bean class="Person" id="person">
         
    <property name="mobileInterface">
             
    <ref local="mobileInterface"></ref>
         
    </property>
    </bean> 
    <bean class="Mobile" id="mobileInterface"></bean>
    這樣,Person類在實現撥打電話的時候,并不知道Mobile類的存在,它只知道調用一個接口MobileInterface,而MobileInterface的具體實現是通過Mobile類完成,并在使用時由容器自動注入,這樣大大降低了不同類間相互依賴的關系。

    什么叫控制反轉呢?
    套用好萊塢的一句名言就是:你呆著別動,到時我會找你。
    什么意思呢?就好比一個皇帝和太監
    有一天皇帝想幸某個美女,于是跟太監說,今夜我要寵幸美女
    皇帝往往不會告訴太監,今晚幾點會回宮,會回哪張龍床,他只會告訴太監他要哪位美女
    其它一切都交由太監去安排,到了晚上皇帝回宮時,自然會有美女出現在皇帝的龍床上
    這就是控制反轉,而把美女送到皇帝的寢宮里面去就是注射
    太監就是是框架里面的注射控制器類BeanFactory,負責找到美女并送到龍床上去
    整個后宮可以看成是Spring框架,美女就是Spring控制下的JavaBean
    而傳統的模式就是一個饑渴男去找小姐出臺
    找領班,幫助給介紹一個云云,于是領班就開始給他張羅
    介紹一個合適的給他,完事后,再把小姐還給領班,下次再來
    這個過程中,領班就是查詢上下文Context,領班的一個職能就是給客戶找到他們所要的小姐
    這就是lookup()方法,領班手中的小姐名錄就是JNDI//Java Naming and Directory Interface
    小姐就是EJB,饑渴男是客戶端,青樓是EJB容器
    看到區別了么?饑渴男去找小姐出臺很麻煩,不僅得找,用完后還得把小姐給還回去
    而皇帝爽翻了,什么都不用管,交給太監去處理,控制權轉移到太監手中去了
    而不是皇帝,必要時候由太監給注射進去就可以了
    看到Spring的美妙了吧,Spring還提供了與多個主流框架的支持
    可以和其它開源框架集成 

    posted on 2010-07-19 11:21 常言笑 閱讀(1465) 評論(0)  編輯  收藏 所屬分類: 技術總結

    My Links

    Blog Stats

    常用鏈接

    留言簿(5)

    隨筆分類

    隨筆檔案

    搜索

    積分與排名

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 在线看片免费人成视频久网下载 | 亚洲Aⅴ无码一区二区二三区软件| 久久夜色精品国产噜噜亚洲AV| 男女一进一出抽搐免费视频| 亚洲欧洲自拍拍偷综合| 免费无码一区二区三区蜜桃| 亚洲无av在线中文字幕| a毛片在线看片免费| 亚洲成a人片在线观看无码| 国产色爽免费无码视频| 亚洲一本综合久久| 16女性下面扒开无遮挡免费| 国产jizzjizz视频免费看| 亚洲AV无码资源在线观看| 国产成人免费片在线视频观看| 免费人成视频在线观看免费| 久久亚洲国产成人影院网站| 中文在线观看永久免费| 亚洲尹人香蕉网在线视颅| 日韩av无码成人无码免费| 亚洲Av永久无码精品一区二区| 四虎影视精品永久免费| 国产男女爽爽爽免费视频| 婷婷久久久亚洲欧洲日产国码AV| 亚洲高清免费在线观看| 日韩亚洲国产综合高清| 亚洲AV无码成人精品区大在线| 皇色在线免费视频| 亚洲综合久久成人69| 国产精品色午夜免费视频| 国产高清视频免费在线观看| 色婷婷六月亚洲婷婷丁香| 日韩一区二区在线免费观看| 亚洲男人天堂影院| 日韩一级在线播放免费观看| 国产一级a毛一级a看免费人娇| 亚洲成aⅴ人在线观看| 成人亚洲综合天堂| 在线看片免费人成视久网| 亚洲AV色欲色欲WWW| 亚洲AV成人片色在线观看高潮|