Java編程語言程序的認識誤區

愈來愈多人開始使用Java,可是他們大多數人沒有作好足夠的思想準備(沒有接受OO思想體系相關培訓),以至不能很好駕馭Java項目,甚至致使開發後的Java系統性能緩慢甚至常常當機。不少人以爲這是Java複雜致使,其實根本緣由在於:咱們原先掌握的關於軟件知識(OO方面)不是太貧乏就是不恰當,存在認識上和方法上的誤區。

  軟件的生命性

  軟件是有生命的,這多是老調重彈了,可是由於它事關分層架構的起因,反覆強調都不過度。
  一個有生命的軟件首先必須有一個靈活可擴展的基礎架構,其次纔是完整的功能。
  目前不少人對軟件的思想仍是焦點落在後者:完整的功能,以爲一個軟件功能越完整越好,其實關鍵仍是架構的靈活性,就是前者,基礎架構好,功能添加只是時間和工做量問題,可是若是架構很差,功能再完整,也不可能包括將來全部功能,軟件是有生命的,在將來成長時,更多功能須要加入,可是由於基礎架構不靈活不能方便加入,死路一條。
  正由於普通人對軟件存在短視誤區,對功能追求高於基礎架構,不少吃了虧的老程序員就此離開軟件行業,帶走寶貴的失敗經驗,新的盲目的年輕程序員仍是使用老的思惟往前衝。其實不少國外免費開源框架如ofbiz compiere和slide也存在這方面陷阱,貌似很是符合胃口,其實相似國內那些幾百元的盜版軟件,擴展性以及持續發展性嚴重不足。
  那麼選擇如今一些流行的框架如Hibernate、Spring/Jdonframework是否就表示基礎架構打好了呢?其實還不盡然,關鍵仍是取決於你如何使用這些框架來搭建你的業務系統。
  存儲過程和複雜SQL語句的陷阱
  首先談談存儲過程使用的誤區,使用存儲過程架構的人覺得能夠解決性能問題,其實它正是致使性能問題的罪魁禍首之一,打個比喻:若是一我的頻臨死亡,打一針可讓其延長半年,可是打了這針,其餘全部醫療方案就所有失效,請問你會使用這種短視方案嗎?
  爲何這樣說呢?若是存儲過程都封裝了業務過程,那麼運行負載都集中在數據庫端,要中間J2EE應用服務器幹什麼?要中間服務器的分佈式計算和集羣能力作什麼?只能回到過去集中式數據庫主機時代。如今軟件都是面向互聯網的,不象過去那樣侷限在一個小局域網,多用戶併發訪問量都是沒法肯定和衡量,依靠一臺數據庫主機顯然是不可以承受這樣惡劣的用戶訪問環境的。(固然搞數據庫集羣也只是五十步和百步的區別)。
  從分層角度來看,如今三層架構:表現層、業務層和持久層,三個層次應該分割明顯,職責分明:持久層職責持久化保存業務模型對象,業務層對持久層的調用只是幫助咱們激活曾經委託其保管的對象,因此,不能由於持久層是保管者,咱們就以其爲核心圍繞其編程,除了要求其歸還模型對象外,還要求其作其作複雜的業務組合。打個比喻:你在火車站將水果和盤子兩個對象委託保管處保管,過了兩天來取時,你還要求保管處將水果去皮切成塊,放在盤子裏,作成水果盤給你,合理嗎?
  上面是談過度依賴持久層的一個現象,還有一個正好相反現象,持久層散發出來,開始擠佔業務層,腐蝕業務層,整個業務層處處看見的是數據表的影子(包括數據表的字段),而不是業務對象。這樣程序員應該多看看OO經典PoEAA.PoEAA 認爲除了持久層,不該該在其餘地方看到數據表或表字段名。
  固然適量使用存儲過程,使用數據庫優勢也是容許的。按照Evans DDD理論,能夠將SQL語句和存儲過程做爲規則Specification一部分。

  Hibernate等ORM問題

  如今使用Hibernate人也很多,可是他們發現Hibernate性能緩慢,因此尋求解決方案,其實並非 Hibernate性能緩慢,而是咱們使用方式發生錯誤:
  "最近本人正搞一個項目,項目中咱們用到了struts1.2+hibernate3, 因爲關係複雜表和表之間的關係不少,在不少地方把lazy都設置false,因此致使數據一加載很慢,並且查詢一條數據更是很是的慢。"
  Hibernate是一個基於對象模型持久化的技術,所以,關鍵是咱們須要設計出高質量的對象模型,遵循DDD領域建模原則,減小下降關聯,經過分層等有效辦法處理關聯。若是採起圍繞數據表進行設計編程,加上表之間關係複雜(沒有科學方法處理、偵察或減小這些關係),必然致使 系統運行緩慢,其實一樣問題也適用於當初對EJB的實體Bean的CMP抱怨上,實體Bean是Domain Model持久化,若是不首先設計Domain Model,而是設計數據表,和持久化工具設計目標背道而馳,能不出問題嗎?關於這個問題N多年就在Jdon爭論過。
  這裏一樣延伸出另一個問題:數據庫設計問題,數據庫是否須要在項目開始設計?
  若是咱們進行數據庫設計,那麼就產生了一系列問題:當咱們使用Hibernate實現持久保存時,必須考慮事先設計好的數據庫表結構以及他們的關係如何和業務對象實現映射,這其實是很是難實現的,這也是不少人以爲使用ORM框架棘手根本緣由所在。
  固然,也有腦力至關發達的人能夠實現,可是這種圍繞數據庫實現映射的結果必然扭曲業務對象,這相似於兩個板塊(數據表和業務對象)相撞,必然產生地震,地震的結果是兩敗俱傷,軟的一方吃虧,業務對象是代碼,至關於數據表結構,屬於軟的一方,最後致使業務對象變成數據傳輸對象DTO, DTO滿天飛,性能和維護問題隨之而來。
  領域建模解決了上述衆多不協調問題,特別是ORM痛苦使用問題,關於 ORM/Hibernate使用仍是那句老話:若是你不掌握領域建模方法,那麼就不要用Hibernate,對於這個層次的你:也許No ORM 更是一個簡單之道: No ORM: The simplest solution

  Spring分層矛盾問題

  Spring是以挑戰EJB面貌出現,其自己擁有的強大組件定製功能是優勢,可是存在實戰的一些問題,Spring做爲業務層框架,不支持業務層Session 功能。
  具體舉例以下:當咱們實現購物車之類業務功能時,須要將購物場合保存到 Session中,因爲業務層沒有方便的Session支持,咱們只得將購物車保存到 HttpSession,而HttpSession只有經過HttpRequest才能得到,再由於在Spring業務層容器中是沒法訪問到 HttpRequest這個對象的,因此,最後咱們只能將"購物車保存到HttpSession"這個功能放在表現層中實現,而這個功能明顯應該屬於業務層功能,這就致使咱們的Java項目層次混亂,維護性差。 違背了使用Spring和分層架構最初目的。

  領域驅動設計DDD

  如今回到咱們討論的重點上來,分層架構是咱們使用Java的根本緣由之一,域建模專家Eric Evans在他的"Domain Model Design"一書中開篇首先強調的是分層架構,整個DDD理論實際是告訴咱們如何使用模型對象oo技術和分層架構來設計實現一個Java項目。
  咱們如今不少人知道Java項目基本有三層:表現層 業務層和持久層,當咱們執着於討論各層框架如何選擇之時,實際上咱們真正的項目開發工做尚未開始,就是咱們選定了某種框架的組合(如Struts+Spring+Hibernate或Struts+EJB或Struts+ JdonFramework),咱們尚未意識到業務層工做還須要大量工做,DDD提供了在業務層中再劃分新的層次思想,如領域層和服務層,甚至再細分爲做業層、能力層、策略層等等。經過層次細化方式達到複雜軟件的鬆耦合。DDD提供瞭如何細分層次的方式
  當咱們將精力花費在架構技術層面的討論和研究上時,咱們可能忘記以何種依據選擇這些架構技術?選擇標準是什麼?領域驅動設計DDD 回答了這樣的問題,DDD會告訴你若是一個框架不能協助你實現分層架構,那就拋棄它,同時,DDD也指出選擇框架的考慮目的,使得你不會人云亦云,陷入複雜的技術細節迷霧中,迷失了架構選擇的根本方向。
  如今也有些人誤覺得DDD是一種新的理論,其實DDD和設計模式同樣,不是一種新的理論,而是實戰經驗的總結,它將前人 使用面向模型設計的方法經驗提煉出來,供後來者學習,以便迅速找到駕馭咱們軟件項目的根本之道。程序員

相關文章
相關標籤/搜索