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

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

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

    posts - 4,comments - 30,trackbacks - 0
    有人說spring?aop+?spring?ioc,?才~~~是spring
    簡單一點,是一個容器.?什么容器,容納什么?是對象,或者說bean的容器.
    那為什么叫輕量級容器呢?相對于EJB?container,使用spring不需要寫符合容器規范的代碼,即容器不會"侵入"了你的代碼.

    這個容器會提供你的應用(程序)中用到的所有對象,并對這些對象進行統一的生命周期管理和組裝.在通常的開發中,我們在需要某個對象的時候只是?new?MyObject().?在Java中,這樣沒有什么不好,因為gc會打理好"善后"工作,是系統級的.?而用spring,在需要某個對象時,只要向容器請求相應的對象,spring會找到并準備好這些對象并提供給你.她也會打理好"善后"工作,但是是在應用級的.
    另一方面,spring還會幫助你打理對象之間的依賴關系.
    比如原來的做法:

    class?A{
    }
    class?B{
    ??A?a?;
    ??public?B(){?a?=?new?A();}
    }

    而使用spring的做法
    class?A{
    }
    class?B{
    ??A?a;
    ??public?B(){}
    ??void?setA(A?a){this.a=a}
    ??A?getA(){return?this.a}
    }
    (希望你不要單純地認為spring會寫很多代碼)
    但從前一個方面,你可能覺得spring只是一個對象容器.從這里你就應該看出,spring是bean容器,因為spring需要你的類符合bean規范:相應于每一個成員域,都需要提供setter和getter方法.spring要使用這些方法來注入依賴關系,也就是?dependence?injection,?或者inversion?of?control.?我個人覺得還是di更容易理解,直到現在我還是要考慮怎么去向別人很好的解釋ioc.控制反轉(倒轉),我的理解是就如同上面的兩個例子里看到的,依賴(控制)不在體現在代碼邏輯里(如第一個例子),而是在配置文件里,而在代碼中我們只提供注入點(也就是setter和getter).

    希望我對IoC的概念的講解能夠給你一些啟發.
    你可能要問了,為什么我要這樣做呢?原來的做法有什么不妥的地方么?沒有什么不妥,只是兩種理念而已,沒有絕對的好還是不好,但我還是給你我的解釋--我理解的IoC的好處,希望有所幫助.通常在程序設計的時候,我們在需要某些功能時,會相應的去設計一些方法,然后根據OO去將方法和一成員變量組成一個類.實際上,我們最終設計出的程序是:一組類的實例互相交互完成某個特定的任務.
    除了一些核心的業務方法,以外我們還要做組裝對象的工作.比如我有了一個工廠,里面有很多機器,機器在開動時要裝配相應的模具.那么在工廠的生產過程中,?首先我要有工廠,機器,模具這樣三個類.然后我的"動作"有:裝配,開機.通常的做法我們要做裝配,然后再去開機.而用spring,我們只是專注于開機.這樣我們就把裝配這個動作抽離出了核心的"生產過程".當某些機器改變了裝配模具時,不在需要修改核心業務代碼.這就是解耦.如:

    public?class?Production{
    ??public?static?void?main(String[]?args){
    ????Factory?factory?=?(Factory)BeanFactory.getBean("factory");
    ????factory.launchProduction();
    ??}
    }

    class?Factory{
    ??Machine?machine1,machine2;
    ??void?launchProduction(){
    ?????machine1.start();?machine2.start();
    ??}
    ??//?setters?and?getters
    }

    class?Machine{
    ??Tool?tool;
    ??void?start(){
    ??}
    ??//?setters?and?getters
    }

    在launchProduction()方法中只需要開動每臺機器即可.而不需要每次都裝配機器.裝配的工作交給了別人.現在只要按下start按鈕.生產就開始了!要是原來:

    void?launchProduction(){
    ??machine1?=?new?MachineA();
    ??machine1.setTool(new?ToolA());
    ??machine2?=?new?MachineB();
    ??machine2.setTool(new?ToolB());
    ??machine1.start();
    ??machine2.start();
    }

    這就是工作分工,是不是感覺輕松了許多?從此以后,我們都是面向構件去開發,而不需要過多地在代碼中體現構件之間的依賴關系.

    AOP
    推薦你看一下<<effective?enterprise?java>>的第一章,對AOP有很清晰,易懂的解釋.其實AOP并非很艱深晦澀的概念,但是從架構角度去理解她的重要性可能不是我這樣的new?fish一時半會兒可以領悟到的.
    我這里只是想說,有些概念你要知道是怎么回事,但理解到多深,除了天賦以外更多的是經驗和悟.所以不要心急.--像是在自我解嘲.
    也許在不知不覺中你就使用了很多AOP的概念,比如servlet里的filter,比如在寫一個command類時,給她的調用類在每次調用command時前后加上:preProcess和postProcess...
    我不想解釋太多,<<eej>>的解釋已經足夠.
    posted on 2006-09-28 13:31 蠻哥♂楓 閱讀(119) 評論(0)  編輯  收藏

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 免费国产a理论片| 亚洲国产精品久久久久秋霞小| 乱爱性全过程免费视频| 在线视频免费国产成人| 亚洲一卡2卡3卡4卡5卡6卡| 岛国av无码免费无禁网站| 亚洲 日韩 色 图网站| 成人毛片18女人毛片免费| 亚洲熟伦熟女专区hd高清| 午夜无遮挡羞羞漫画免费| 亚洲а∨精品天堂在线| 人人狠狠综合久久亚洲高清| 一级黄色毛片免费看| 亚洲香蕉网久久综合影视| 免费福利在线视频| 亚洲国产日韩在线| 大陆一级毛片免费视频观看| 亚洲sm另类一区二区三区| 亚洲国产人成精品| 免费av一区二区三区| 亚洲av专区无码观看精品天堂| 午夜视频在线在免费| 免费国产黄网站在线观看动图| 亚洲精品无码成人AAA片| 久草免费在线观看视频| 色综合久久精品亚洲国产| 中文字幕精品无码亚洲字| 国产精品区免费视频| 亚洲一卡2卡4卡5卡6卡在线99| 永久免费无码网站在线观看| 人成电影网在线观看免费| 亚洲精品无码不卡| 免费高清小黄站在线观看| 国产成人无码精品久久久免费| 亚洲人成亚洲精品| 国产片免费在线观看| 国产成人精品免费久久久久| 亚洲精品国产国语| 日韩一卡2卡3卡4卡新区亚洲 | 四虎影视成人永久免费观看视频| 亚洲不卡1卡2卡三卡2021麻豆|