日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

當前Java軟件開發中幾種認識誤區

瀏覽:216日期:2024-06-09 11:43:45

越來越多人開始使用Java,但是他們大多數人沒有做好足夠的思想準備(沒有接受OO思想體系相關培訓),以致不能很好駕馭Java項目,甚至導致開發后的Java系統性能緩慢甚至經常當機。很多人覺得這是Java復雜導致,其實根本原因在于:我們原先掌握的關于軟件知識(OO方面)不是太貧乏就是不恰當,存在認識上和方法上的誤區。

軟件的生命性

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

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

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

正因為普通人對軟件存在短視誤區,對功能追求高于基礎架構,很多吃了虧的老程序員就此離開軟件行業,帶走寶貴的失敗經驗,新的盲目的年輕程序員還是使用老的思維往前沖。其實很多國外免費開源框架如ofbiz compiere和slide也存在這方面陷阱,貌似非常符合胃口,其實類似國內那些幾百元的盜版軟件,擴展性以及持續發展性嚴重不足。

那么選擇現在一些流行的框架如Hibernate、Spring/Jdonframework是否就表示基礎架構打好了呢?其實還不盡然,關鍵還是取決于你如何使用這些框架來搭建你的業務系統。

存儲過程和復雜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,而是設計數據表,和持久化工具設計目標背道而馳,能不出問題嗎?關于這個問題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和設計模式一樣,不是一種新的理論,而是實戰經驗的總結,它將前人 使用面向模型設計的方法經驗提煉出來,供后來者學習,以便迅速找到駕馭我們軟件項目的根本之道。

現在Evans DDD概念很火,因為它將著名的PoEAA進行了具化,實現了PoEAA可操作性,這也是MF大力推崇的原因。最近(8月8日)一位老外博客上用微軟的.NET架構和Evans DDD比較的文章:比較了微軟的三層服務應用架構[Microsoft TLSA]和Evans DDD的架構, 使用Microsoft .NET Pet Shop 4為例子,解釋兩個目標的區別,并且表明微軟是如何在案例中更好地實現支持后者。這篇文章幫助哪些.NET平臺上有域設計知識的人實現更好地提高。

另外一本關于.NET的DDD書籍也已經出版,這些都說明Evans DDD這把火已經燒到.NET領域,當然DDD在Java領域生根開花多年,Evans的DDD書籍就是以Java為例子的,筆者板橋里人也率先在2005年推出DDD框架JdonFramework 1.3版本,這些都說明,Java在整個軟件業先進思想的實踐上總是領先一步。

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美不卡视频| 欧美特黄a级高清免费大片a级| 丝袜美腿成人在线| 99精品99| 免费看黄色91| 日韩在线观看中文字幕| 亚洲va久久| 69精品国产久热在线观看| 欧美一级网址| 久久影院资源站| 中文一区一区三区高中清不卡免费| 色偷偷偷在线视频播放| 91免费精品| 婷婷成人综合| 另类激情亚洲| 日本成人在线一区| 国产极品久久久久久久久波多结野| 欧美aⅴ一区二区三区视频| 欧美精品91| 日韩精品第一区| 蜜臀久久99精品久久一区二区 | 国产精品一区亚洲| 国产激情欧美| 亚洲精品在线影院| 欧美天堂亚洲电影院在线观看| 日韩午夜免费| 日本欧美一区二区在线观看| 国产激情久久| 欧美日韩水蜜桃| 亚洲欧美网站在线观看| 国产欧美日韩免费观看| 激情久久一区二区| 国产专区一区| 日韩国产在线不卡视频| 国内精品亚洲| 好吊日精品视频| 青青国产精品| 日韩精品看片| 日韩区欧美区| 亚洲精品88| 中文在线日韩| 精品一区二区三区在线观看视频| 激情欧美一区二区三区| 日本综合精品一区| 天堂√8在线中文| 石原莉奈一区二区三区在线观看| 国产精品久久久久久久久久妞妞 | 在线视频精品| 国产日韩欧美一区二区三区 | 国产成人精品三级高清久久91| 亚洲性视频h| 国产精品亚洲综合色区韩国| 精品国产美女a久久9999| 九一精品国产| 国产精品久久久久久久久久白浆| 激情婷婷久久| 久久gogo国模啪啪裸体| 伊人久久亚洲热| 麻豆视频观看网址久久| 亚洲激情黄色| 国产精品一在线观看| 欧美另类专区| 精品久久中文| 日韩在线网址| 久久精品av| 麻豆一区二区三| 综合激情网站| 精品欧美一区二区三区在线观看| 欧美成人亚洲| 国产精品啊v在线| 国产麻豆精品| 国产在线观看www| 一区二区国产精品| 成人在线网站| 国产精品一区二区三区美女| 一区福利视频| 精品捆绑调教一区二区三区| 国产日韩欧美三级| 在线综合亚洲| 日本少妇一区| 久久精品国产福利| 日本不卡中文字幕| 久久国产主播| 精品不卡一区| 国产精品hd| 婷婷亚洲成人| 免费久久99精品国产自在现线| 国产一区二区三区网| 欧美在线91| 免费一级片91| 好吊日精品视频| 激情久久久久久久| 日韩综合精品| 国产99在线| 久久久91麻豆精品国产一区| 青青国产91久久久久久| 免费看精品久久片| 国产一区亚洲| 青青青免费在线视频| 国产精品欧美一区二区三区不卡| 日韩影院精彩在线| 尤物精品在线| 亚洲高清激情| 久久国产日韩| 久久视频精品| 日本免费一区二区三区四区| 国内不卡的一区二区三区中文字幕| 国产精品一区二区三区www| 日韩va欧美va亚洲va久久| 首页亚洲欧美制服丝腿| 欧美日韩国产一区精品一区| 欧美精品一二| 亚洲免费福利| 女生影院久久| 99精品视频精品精品视频| 欧美日韩免费观看视频| 欧洲一级精品| 激情综合网站| 久久福利影视| 亚洲资源网站| 日韩av一区二区在线影视| 日本a级不卡| 欧美性www| 国产精品久久久免费| 欧美国产另类| 国产精品成人一区二区不卡| 国产一区2区在线观看| 久久精品一区二区国产| 美日韩一区二区三区| 久久久精品区| 日韩欧美自拍| 天堂网在线观看国产精品| 妖精视频成人观看www| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲色图网站| 日本天堂一区| 国产精品v亚洲精品v日韩精品| 欧美激情99| 亚洲黄色网址| 中文日韩在线| 日本99精品| 精品午夜av| 亚洲一区资源| 欧美日韩国产亚洲一区| 最新国产精品视频| 国产精品视频一区视频二区| 国产一区二区亚洲| 国产在线不卡| 日本成人在线网站| 成人在线观看免费视频| 国内亚洲精品| 亚洲精品四区| 欧美经典一区| 成人羞羞视频播放网站| 亚洲一区国产| 国产麻豆精品久久| 日韩国产网站| 免费日韩精品中文字幕视频在线| 日韩中文字幕视频网| 精品国内亚洲2022精品成人| 久久久夜精品| 少妇精品久久久| 欧美成人一二区| 美女少妇全过程你懂的久久| 午夜亚洲福利| 不卡专区在线| 男女男精品网站| 精品国产麻豆| 国产视频亚洲| 国产精品九九| 欧美日韩国产高清电影| 五月激激激综合网色播| 欧美91在线| 不卡中文一二三区| 国产亚洲一区二区三区不卡| 91看片一区| 69堂免费精品视频在线播放| 亚洲爱爱视频| 91精品国产经典在线观看| 欧美日韩精品免费观看视完整| 亚洲精选久久| 一本大道色婷婷在线| 奇米777国产一区国产二区| 日韩一区二区在线免费| 亚洲18在线| 久久精品二区三区| 欧美在线看片| 91精品国产乱码久久久久久久| 视频一区中文字幕精品| 99精品综合| 国产精品色婷婷在线观看| 一区免费在线| 国产成人免费| 亚洲日韩视频| 久久久国产精品一区二区中文| 欧美一级一区| 在线视频亚洲| 在线看片国产福利你懂的| 911亚洲精品| 亚洲一区二区三区免费在线观看|