隨筆-55  評論-208  文章-0  trackbacks-0
          最近在新公司學習一個新框架:UMA,是Cloverworxs的,不是開源項目,也不是商業(yè)項目,所以google上是找不到的
          這個框架是老美設計,感覺他們在邏輯的抽象上功底更強一些,這個應該和軟件開發(fā)的大環(huán)境經(jīng)驗積累有關系吧。
          首先先他把一個request發(fā)給controller,controller根據(jù)service(service是使用spring加載的,主要用于封裝handler和target)把請求封裝后發(fā)給handler,handler根據(jù)請求參數(shù)找到fenture,而feature則根據(jù)請求參數(shù)交給具體action來處理。action主要就是調(diào)用業(yè)務模型層的接口了。然后action處理完之后會返回到controller,controller根據(jù)service調(diào)用target,target則調(diào)用配置的render(可能多個),然后rende從業(yè)務模型層的接口中取回數(shù)據(jù)并進行顯示準備,最后把數(shù)據(jù)封裝到一個RDO中,然后把RDO放置到attribute中,然后再頁面上讀取顯示。

          初學這個框架,看得是作者的英文文檔,首先得感覺是層次的抽象的有些細,因為以往做過的項目中,render和handler,feature的代碼都是放在控制層來處理了(通常是struts的action)。但是這種詳細層次也能感覺到的好處就是,當某一層次要變動時不需要到action中去找變動代碼,而且當出于某種考慮要針對于某一層進行統(tǒng)一處理(如安全性處理)時就比較方便了。

          看完文檔覺得對框架已經(jīng)有了一個深入的認識,開發(fā)時應該比較快上手了吧,但是實踐中卻發(fā)現(xiàn),在每一層的實現(xiàn)代碼中由于框架引入了很多的完善特性,所以每一層的代碼有很多細節(jié)的實現(xiàn)問題是需要一點一點理解去掌握的。而且學習的代碼是一個完整的項目,這個完整的項目有一個問題就是,有幾十個模塊,模塊間的代碼有相互耦合的問題,反而造成了我閱讀代碼的困難。結(jié)果用了一個多禮拜的時間才算基本上手框架。
          總結(jié)問題,發(fā)現(xiàn)主要有兩個:
          1、太過相信文檔,其實文檔只是一個大體框架的介紹。所以我應該多和有經(jīng)驗的開發(fā)者交流,并且要配合代碼具體細節(jié)
          2、一個框架應該有一個簡單的清晰的demo,只涉及一個模塊,清晰,明確,這樣就不會再閱讀學習時陷入模塊邏輯和框架邏輯中。因為從代碼中你很難分辨出哪些是框架邏輯,哪些是模塊邏輯。
          posted on 2007-03-31 12:41 rocket 閱讀(2103) 評論(4)  編輯  收藏

          評論:
          # re: 框架學習新體會 2007-04-01 15:32 | sunflower
          是不是這種框架
          調(diào)用時:----------------------------------------------

          1.表現(xiàn)層->控制層->Service->Action->業(yè)務層
          Sevice(handler,feature,target)
          Render

          返回時:----------------------------------------------
          1.控制層<-Action<-業(yè)務層
          2.控制層->Service->render->業(yè)務層
          3.表現(xiàn)層<-控制層<-Action(封裝RDO?)<-業(yè)務層<-持久層

          有幾個問題問問:
          1.這是SOA的框架么?
          2.每一層應該是獨立的.特別是控制層,業(yè)務層,持久層并不受Action影響.
          對每一個服務,只需配置一個Service就行,可插件式的應用,之后Sevice通過從業(yè)務層得到的參數(shù)來使用RDO來封裝數(shù)據(jù).是不是數(shù)據(jù)模型都有特定的人封裝好了,你只是拿來拼湊層RDO?
          你只需要做Service層對吧.
          持久層應該只調(diào)用一次,就是封撞RDO時調(diào)用.
          ---------------------------------------------------
          RDO以前沒聽過:
          RDO (Remote Data Objects) 遠程數(shù)據(jù)對象是一個到 ODBC 的、面向?qū)ο蟮臄?shù)據(jù)訪問接口,它同易于使用的 DAO style組合在一起,提供了一個接口,形式上展示出所有 ODBC 的底層功能和靈活性。盡管 RDO 在很好地訪問 Jet 或 ISAM 數(shù)據(jù)庫方面受到限制,而且它只能通過現(xiàn)存的 ODBC 驅(qū)動程序來訪問關系數(shù)據(jù)庫。但是,RDO 已被證明是許多 SQL Server、Oracle 以及其他大型關系數(shù)據(jù)庫開發(fā)者經(jīng)常選用的最佳接口。RDO 提供了用來訪問存儲過程和復雜結(jié)果集的更多和更復雜的對象、屬性,以及方法。   回復  更多評論
            
          # re: 框架學習新體會[未登錄] 2007-04-02 15:36 | rocket
          @sunflower
          rdo = render Data Object
          專門用于封裝頁面顯示數(shù)據(jù)的  回復  更多評論
            
          # re: 框架學習新體會 2007-04-05 19:19 | sunflower
          能不能解釋的稍微多點呢?例如框架  回復  更多評論
            
          # re: 框架學習新體會 2008-01-07 03:35 | javayuan
          service不就是業(yè)務層么?  回復  更多評論
            

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


          網(wǎng)站導航:
           
          Dict.CN 在線詞典, 英語學習, 在線翻譯
          點擊這里給我發(fā)消息QQ:19794405
          agilelife分享群:59765983   
          QQ上少了,請大家加入msn group:
          agilelife@groups.msn.com
          敏捷項目實踐經(jīng)驗分享
          TDD,重構(gòu),迭代,結(jié)對
          <2007年4月>
          25262728293031
          1234567
          891011121314
          15161718192021
          22232425262728
          293012345

          常用鏈接

          留言簿(7)

          我參與的團隊

          隨筆分類(15)

          隨筆檔案(55)

          相冊

          搜索

          •  

          積分與排名

          • 積分 - 133611
          • 排名 - 464

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 改则县| 贺州市| 盐亭县| 洞头县| 麦盖提县| 周至县| 交城县| 平武县| 阿尔山市| 石屏县| 通化市| 滨海县| 通辽市| 连云港市| 漳平市| 龙南县| 顺昌县| 营口市| 民丰县| 新龙县| 屏南县| 泽州县| 临夏市| 三河市| 礼泉县| 武平县| 临沧市| 宁国市| 元阳县| 朝阳区| 江陵县| 台湾省| 冀州市| 惠州市| 乌海市| 杭锦旗| 泰兴市| 衢州市| 徐汇区| 邹平县| 安义县|