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

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

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

    莊周夢蝶

    生活、程序、未來
       :: 首頁 ::  ::  :: 聚合  :: 管理

    java package的設計原則

    Posted on 2008-09-06 00:15 dennis 閱讀(2998) 評論(3)  編輯  收藏 所屬分類: java
        典型的J2EE項目,package的設計有成熟的套路可循,如分為domain、dao、service、action等等,職責已經分解的比較單一和清晰,循環依賴這樣的情況出現并不多。而在一般的java項目,如服務器程序、客戶端程序和通用性框架的開發中,包的設計并沒有套路可循,畢竟由于應用和業務種類的不同,想得出通用性的設計套路是不大可能的。這時候遵循一些原則比之生搬硬套更為重要。在《敏捷軟件開發》一書中對包的設計有深入的討論,雖然針對的是發布的二進制包而言,但是對于java package的設計同樣有借鑒意義,如對包的內聚性、可重用性、穩定性的強調,對于依賴的探討,這些都是比較籠統的概念,不是那么直觀,需要在實際運用中認真歸納和重構,向這些原則靠攏。
       我所想到一個比較直觀的方法就是:對于一個包的描述,你是否能用一句簡明扼要的話概括,也就是包的功能或者說介紹能否做到簡明扼要,這是衡量一個包的設計是否合理的最簡單的方法。如果可以,顯然這個包的內聚性很好,所有的類都服務于一個目的,從而帶來了重用的可能(其實我對重用性并不感冒,除了工具類外真正能重用的東西少之又少,內聚性才是需要關注的);反之,這個包可能承擔了太多的職責或者依賴過多,仔細的重構和分離是需要做的。包的設計同樣要遵循接口分離的原則,將接口與實現隔離在不同的包之中,客戶程序就不會知道具體的實現,并且也保證了實現對接口的單向依賴。當然,這時就需要引入工廠類、插件或者IOC容器來負責實例化實現類。

    評論

    # re: java package的設計原則  回復  更多評論   

    2008-09-06 10:06 by Jack.Wang
    接口與實現隔離在不同的包之中是個比較好的實踐,贊同。
    關注點分離永遠是軟件開發架構的重點,LZ說重用甚少,開發軟件如果架構允許的話我們都會 import 第三方組件,such as apache commons and so on. commons 重用的原因是因為和業務無關,沒有依賴性,當然和業務有關的也可以重用,這也就是 SOA 的理念之一了。

    # re: java package的設計原則  回復  更多評論   

    2008-09-07 22:19 by dennis
    @Jack.Wang
    重用的粒度問題,而我說談的重用局限在代碼級別的重用。

    # re: java package的設計原則  回復  更多評論   

    2008-09-08 10:11 by zhuxing
    贊同樓主觀點,包的設計應該是在通用的設計原則的指導下完成

    應該以很多個維度來綜合地看待這個問題,盡量考慮到各個規則(例如盡量分離抽象和實現,更好的遵循開閉原則....),不要和經典的規則發生沖突~_~

    有的人可能更喜歡從技術視角進行劃分,例如可能會出現**.factory類型的包,里面放置了供用戶調用的工程類;有的人則可能更喜歡從業務角度進行劃分等。

    大的原則是存在的,具體細節因人而異 ^_^。
    主站蜘蛛池模板: 久久亚洲精品无码观看不卡| 亚洲精品成人区在线观看| 亚洲a在线视频视频| 亚洲网站在线免费观看| 无码专区永久免费AV网站| 亚洲成A人片在线观看中文| 青草久久精品亚洲综合专区| 中文字幕无码免费久久| 日韩va亚洲va欧洲va国产| 日韩亚洲产在线观看| 色哟哟国产精品免费观看| 亚洲?V乱码久久精品蜜桃 | 亚洲国产午夜精品理论片在线播放 | 全免费A级毛片免费看网站| 亚洲另类无码专区丝袜| 一级特黄aa毛片免费观看| 亚洲欧洲第一a在线观看| 免费看一级一级人妻片| 麻豆视频免费观看| 亚洲日韩乱码中文字幕| 免费国产成人高清在线观看麻豆| 亚洲精品乱码久久久久久下载| 亚洲精品免费在线观看| 亚洲ts人妖网站| 免费在线黄色网址| 免费国产在线视频| 亚洲AV无码一区二区二三区入口| 一区二区三区四区免费视频 | 免费大片av手机看片高清| 亚洲乱码一区二区三区在线观看 | 亚洲国产精品无码第一区二区三区 | 一级做a毛片免费视频| 天天干在线免费视频| 新最免费影视大全在线播放| 亚洲AV日韩AV高潮无码专区| 无人在线观看完整免费版视频| 九九久久国产精品免费热6| 亚洲成无码人在线观看| 免费观看四虎精品国产永久| 亚洲a无码综合a国产av中文| 久久久久国产成人精品亚洲午夜|