Read Sean

          Read me, read Sean.
          posts - 508, comments - 655, trackbacks - 9, articles - 4

          導航

          公告


          • 關于我
          • 人生是一場對話
          • gaoyuxiang AT gmail DOT com
          • titlelogo.png

          • 我的譯作
          • Scala for the Impatient
          • Open Source SOA
          • Programming in Scala

          • 聲明
          • 所有文章和代碼在這里以"現(xiàn)狀"提供,作者不提供任何形式的擔保,也沒有授予除閱讀和有條件共享之外的任何權(quán)利。除非特別說明,所有文章均為本blog作者原創(chuàng),如需轉(zhuǎn)載請注明出處和原作者,如用于商業(yè)目的,需作者本人書面許可。

          • 推薦文章
          • Pylons起步

          常用鏈接

          留言簿(29)

          隨筆分類(842)

          隨筆檔案(507)

          文章檔案(4)

          Friends' blogs

          搜索

          •  

          積分與排名

          • 積分 - 783648
          • 排名 - 54

          最新評論

          閱讀排行榜

          評論排行榜

          J2EE應用中常見的反模式(anti-patterns)

          Posted on 2005-07-23 17:01 laogao 閱讀(3291) 評論(0)  編輯  收藏 所屬分類: On Java

            

          J2EE應用中有一些常見的毛病和錯誤的觀念,按照時下流行的說法,叫反模式。稍不注意,我們自己也會犯,所以大概整理一下,一個是備忘,也是供需要的朋友參考:

           

          1- EJB不叫J2EE

          EJB一直發(fā)展到今天的2.1仍然被廣為詬病,它提供了很多時候我們并不需要的東西,而且我們在很多情況下一旦選用EJB就沒有其他的方式不去使用那些笨重的功能。但是很多所謂范例讓我們有一種錯覺,好像不用EJB就不是J2EE應用。有一些折中的方案是使用Session Fa?ade模式,Entity Bean采用BMP + 本地接口,然后提供一層無狀態(tài)的Session Bean,采用遠程和本地接口,這樣的設計模式,我想,多半是出于無奈。如今,甚至我們經(jīng)常都能看到不使用EJB的言論,炒得很火的Spring則為這種完全不用EJB開發(fā)J2EE項目提供了實際的、強有力的佐證。

           

          2- 過度分層

          J2EE這個規(guī)范膚淺的來看,就是為我們定義了很多“層”,然后還有很多分工明確的“角色”,加上J2EE的藍本應用程序就分了很多“層”,以至于大家都覺得J2EE的應用就應該是很多層的,其實不然,需要具體情況具體分析。

           

          3- 頻繁的往返調(diào)用

          EJB的看似簡單造成我們經(jīng)常忽略可能在使用過程中出現(xiàn)的遠程調(diào)用,比如有時候為了更新一條記錄,每個字段都是遠程的去set,大大增加了不必要的開銷,于是我們意識到在調(diào)用中使用DTO是一個建議遵循的方案。

           

          4- 過度使用有狀態(tài)的Session Bean

          一般來講,一個Session Bean實例,如果它是有狀態(tài)的,那么它只對某個固定的用戶服務,如果是無狀態(tài)的,則可以滿足不同用戶的調(diào)用。這有點類似(只是有點類似)一個類的靜態(tài)方法和非靜態(tài)方法的區(qū)別。我們在實際應用中,應該盡量避免使用有狀態(tài)的Session Bean,除非特別必要。我們可以把狀態(tài)保留在Session Bean之外,如Web容器的session對象或者我們自定義的類中,而不是完全依賴有狀態(tài)的Session Bean去幫我們做。

           

          5- 過度會話

          Web容器的session對象是個好東西,用起來也很方便和直截了當,這造成了我們很多人對它的濫用,什么東西都往里面放。這有兩個突出的問題,一個是資源浪費;另一個,萬一Web服務器崩潰,那些本來需要持久化的數(shù)據(jù)就丟失了。我們需要考慮好,哪些數(shù)據(jù)本可以用request的,哪些數(shù)據(jù)又是需要持久化到數(shù)據(jù)庫的,等等,不能一味依賴session

           

          6- 萬能Servlet或者萬能JSP

          J2EE為我們提供了Web層豐富的技術選擇,Servlet或者JSP都只是其中一種,雖然它很強大,但是也不應該由它一個來承擔所有MVC三個部分的功能。現(xiàn)實中我們的Struts很好的規(guī)范了這個問題:Servlet負責調(diào)度,專門的Action負責處理邏輯,而JSP用于用戶界面顯示。JSPServlet本質(zhì)上是同一個東西,只是從不同的角度來處理問題,它們各有所長,互為補充。

           

           

          主站蜘蛛池模板: 玛多县| 碌曲县| 秦安县| 吉安市| 怀远县| 沙坪坝区| 安顺市| 包头市| 蕉岭县| 天柱县| 北京市| 贡山| 文化| 满城县| 双城市| 永定县| 怀远县| 舒城县| 宝山区| 隆林| 县级市| 昭平县| 万安县| 霍林郭勒市| 滕州市| 阳谷县| 神池县| 双流县| 灌云县| 仁怀市| 崇义县| 萨嘎县| 乾安县| 谷城县| 馆陶县| 镇赉县| 胶南市| 沁阳市| 台南市| 姜堰市| 寻乌县|