无码人妻A片一区二区三区_18禁裸乳无遮挡啪啪无码免费_91精品亚?影视在线?看_人人妻人人爽人人澡AV_国产精品人妻一区二区三区四区_午夜免费影视

中培偉業IT資訊頻道
您現在的位置:首頁 > IT資訊 > 軟件研發 > Java開發過程中常見的錯誤觀點

Java開發過程中常見的錯誤觀點

2017-02-07 09:12:00 | 來源:中培企業IT培訓網

隨著Java的重新崛起,越來越多人開始使用Java,但是他們大多數人沒有做好足夠的思想準備,以致不能很好駕馭Java項目。中培偉業《企業級JAVA高級開發技術實戰》培訓專家龔老師認為,出現這一問題的根本原因在于很對開發人員存在認識上和方法上的誤區。

軟件的生命性

軟件是有生命的,這可能是老調重彈了,但是因為它事關分層架構的原由,反復強調都不過分。

一個有生命的軟件首先必須有一個靈活可擴展的基礎架構,其次才是完整的功能。

目前很多人對軟件的思想還是焦點落在后者:完整的功能,覺得一個軟件功能越完整越好,其實關鍵還是架構的靈活性,就是前者,基礎架構好,功能添加只是時間和工作量問題,但是如果架構不好,功能再完整,也不可能包括未來所有功能,軟件是有生命的,在未來成長時,更多功能需要加入,但是因為基礎架構不靈活不能方便加入,死路一條。

正因為普通人對軟件存在短視誤區,對功能追求高于基礎架構,很多吃了虧的老程序員就此離開軟件行業,帶走寶貴的失敗經驗,新的盲目的年輕程序員還是使用老的思維往前沖。

存儲過程和復雜SQL語句的陷阱

首先談談存儲過程使用的誤區,使用存儲過程架構的人以為可以解決性能問題,其實它正是導致性能問題的罪魁禍首之一

為什么這樣說呢?如果存儲過程都封裝了業務過程,那么運行負載都集中在數據庫端,要中間J2EE應用服務器干什么?要中間服務器的分布式計算和集群能力做什么?只能回到過去集中式數據庫主機時代?,F在軟件都是面向互聯網的,不象過去那樣局限在一個小局域網,多用戶并發訪問量都是無法確定和衡量,依靠一臺數據庫主機顯然是不能夠承受這樣惡劣的用戶訪問環境的。

從分層角度來看,現在三層架構:表現層、業務層和持久層,三個層次應該分割明顯,職責分明:持久層職責持久化保存業務模型對象,業務層對持久層的調用只是幫助我們激活曾經委托其保管的對象,所以,不能因為持久層是保管者,我們就以其為核心圍繞其編程,除了要求其歸還模型對象外,還要求其做其做復雜的業務組合。打個比喻:你在火車站將水果和盤子兩個對象委托保管處保管,過了兩天來取時,你還要求保管處將水果去皮切成塊,放在盤子里,做成水果盤給你,合理嗎?

上面是談過分依賴持久層的一個現象,還有一個正好相反現象,持久層散發出來,開始擠占業務層,腐蝕業務層,整個業務層到處看見的是數據表的影子(包括數據表的字段),而不是業務對象。這樣程序員應該多看看OO經典PoEAA。PoEAA 認為除了持久層,不應該在其他地方看到數據表或表字段名。

當然適量使用存儲過程,使用數據庫優點也是允許的。按照Evans DDD理論,可以將SQL語句和存儲過程作為規則Specification一部分。

Hibernate等ORM問題

現在使用Hibernate人也不少,但是他們發現Hibernate性能緩慢,所以尋求解決方案,其實并不是 Hibernate性能緩慢,而是我們使用方式發生錯誤:

“最近本人正搞一個項目,項目中我們用到了struts1.2+hibernate3, 由于關系復雜表和表之間的關系很多,在很多地方把lazy都設置false,所以導致數據一加載很慢,而且查詢一條數據更是非常的慢?!?/p>

Hibernate是一個基于對象模型持久化的技術,因此,關鍵是我們需要設計出高質量的對象模型,遵循DDD領域建模原則,減少降低關聯,通過分層等有效辦法處理關聯。如果采取圍繞數據表進行設計編程,加上表之間關系復雜(沒有科學方法處理、偵察或減少這些關系),必然導致 系統運行緩慢,其實同樣問題也適用于當初對EJB的實體Bean的CMP抱怨上,實體Bean是Domain Model持久化,如果不首先設計Domain Model,而是設計數據表,和持久化工具設計目標背道而馳,能不出問題嗎?

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和設計模式一樣,不是一種新的理論,而是實戰經驗的總結,它將前人 使用面向模型設計的方法經驗提煉出來,供后來者學習,以便迅速找到駕馭我們軟件項目的根本之道。

標簽: Java開發
主站蜘蛛池模板: 久久这里只有 | 嫩草免费视频 | 在线看黄V免费网站免费 | 国产午夜视频线播放器 | 免费日韩中文字幕 | 黑人精品xxx一区一二区 | 高清免费A级在线观看 | 在线午夜av | 久久首页| 中国三级在线 | 97久久超碰国产精品2021 | 内射少妇三洞齐开 | 97久久精品人人做人人爽50路 | 怡红院成人在线 | 百合AV肉片无码资源无码 | 亚洲精品国产一区二区的区别 | 国产精品视频一区在线观看 | 中文字幕av一区二区三区高 | 国产综合13P | 日本黄色录像一级片 | 免费的黄色在线视频 | 无码AV久久久久久久久 | 精品欧美一区二区精品久久久 | 97精品国产99久久久久久免费 | 日韩在线视频线视频免费网站 | 国产精品111 | 亚洲va欧美va人人爽午夜 | 羞羞影院午夜男女爽爽视频免费 | 免费国产不卡一级αⅴ片 | 丰满少妇高潮久久三区 | 草草影视在线观看 | 亚洲蜜芽AV网站 | 九九精品视频在线 | 91在线一区二区 | XYX性爽欧美 | 一区二区三区无码在线观看 | 亚洲av制服丝袜日韩高清 | 中文字幕日本一道 | 亚洲一二区制服无码中字 | 密臀av一区二区三区 | 国产日产综合 |