<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)  編輯  收藏

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


    網站導航:
     
    主站蜘蛛池模板: 亚洲AV无码资源在线观看| 综合自拍亚洲综合图不卡区| 一二三四免费观看在线视频中文版| 永久免费在线观看视频| 四虎免费大片aⅴ入口| 国产免费卡一卡三卡乱码| 中文字幕亚洲日韩无线码| 亚洲国产老鸭窝一区二区三区| 亚洲一区二区三区国产精品无码| 亚洲成a人无码亚洲成www牛牛| 国产性生大片免费观看性| 国产精品免费观看| 亚洲AV日韩精品一区二区三区| 亚洲成AV人片在线观看ww| 自拍日韩亚洲一区在线| 老司机69精品成免费视频| 四虎影视大全免费入口| 亚洲欧美成aⅴ人在线观看| 亚洲免费视频在线观看| 国产精品成人四虎免费视频| 久久精品国产亚洲AV香蕉| 国产VA免费精品高清在线| 成人免费无码视频在线网站| 亚洲男人第一av网站| 国产在线jyzzjyzz免费麻豆| 亚洲熟妇无码一区二区三区导航| 日韩在线播放全免费| 亚洲高清日韩精品第一区| 18禁无遮挡无码网站免费| 精品成人一区二区三区免费视频| 亚洲一级免费毛片| 日韩国产欧美亚洲v片| 亚洲动漫精品无码av天堂| 在免费jizzjizz在线播| 亚洲AV成人一区二区三区观看| 国产成人亚洲精品影院| 一个人看的在线免费视频| 亚洲&#228;v永久无码精品天堂久久| 国产精品美女久久久免费| 亚洲人成网站日本片| 国产卡二卡三卡四卡免费网址 |