現(xiàn)在軟件設(shè)計(jì)里到處都是模式,框架。有次朋友問什么是模式?我也在學(xué)習(xí)中,就我的學(xué)習(xí)經(jīng)驗(yàn),給出以下小結(jié)。(注意:個(gè)人觀點(diǎn),僅供參考,歡迎指正。)
1.什么是模式? 模式,即pattern。其實(shí)就是解決某一類問題的方法論。你把解決某類問題的方法總結(jié)歸納到理論高度,那就是模式。 Alexander給出的經(jīng)典定義是:每個(gè)模式都描述了一個(gè)在我們的環(huán)境中不斷出現(xiàn)的問題,然后描述了該問題的解決方案的核心。通過這種方式,你可以無數(shù)次地使用那些已有的解決方案,無需在重復(fù)相同的工作。 模式有不同的領(lǐng)域,建筑領(lǐng)域有建筑模式,軟件設(shè)計(jì)領(lǐng)域也有設(shè)計(jì)模式。當(dāng)一個(gè)領(lǐng)域逐漸成熟的時(shí)候,自然會(huì)出現(xiàn)很多模式。 什么是框架? 框架,即framework。其實(shí)就是某種應(yīng)用的半成品,就是一組組件,供你選用完成你自己的系統(tǒng)。簡(jiǎn)單說就是使用別人搭好的舞臺(tái),你來做表演。而且,框架一般是成熟的,不斷升級(jí)的軟件。 2.為什么要用模式? 因?yàn)槟J绞且环N指導(dǎo),在一個(gè)良好的指導(dǎo)下,有助于你完成任務(wù),有助于你作出一個(gè)優(yōu)良的設(shè)計(jì)方案,達(dá)到事半功倍的效果。而且會(huì)得到解決問題的最佳辦法。 為什么要用框架? 因?yàn)檐浖到y(tǒng)發(fā)展到今天已經(jīng)很復(fù)雜了,特別是服務(wù)器端軟件,設(shè)計(jì)到的知識(shí),內(nèi)容,問題太多。在某些方面使用別人成熟的框架,就相當(dāng)于讓別人幫你完成一些基礎(chǔ)工作,你只需要集中精力完成系統(tǒng)的業(yè)務(wù)邏輯設(shè)計(jì)。而且框架一般是成熟,穩(wěn)健的,他可以處理系統(tǒng)很多細(xì)節(jié)問題,比如,事物處理,安全性,數(shù)據(jù)流控制等問題。還有框架一般都經(jīng)過很多人使用,所以結(jié)構(gòu)很好,所以擴(kuò)展性也很好,而且它是不斷升級(jí)的,你可以直接享受別人升級(jí)代碼帶來的好處。 框架一般處在低層應(yīng)用平臺(tái)(如J2EE)和高層業(yè)務(wù)邏輯之間的中間層。 軟件為什么要分層? 為了實(shí)現(xiàn)“高內(nèi)聚、低耦合”。把問題劃分開來各個(gè)解決,易于控制,易于延展,易于分配資源…總之好處很多啦:)。 3.以下所述主要是JAVA,J2EE方面的模式和框架: 常見的設(shè)計(jì)模式有什么? 首先,你要了解的是GOF的《設(shè)計(jì)模式--可復(fù)用面向?qū)ο筌浖幕A(chǔ)》一書(這個(gè)可以說是程序員必備的了),注意:GOF不是一個(gè)人,而是指四個(gè)人。它的原意是Gangs Of Four,就是“四人幫”,就是指此書的四個(gè)作者:Erich Gamma,Richard Helm,Ralph Johnson,John Vlissides。這本書講了23種主要的模式,包括:抽象工廠、適配器、外觀模式等。 還有其他的很多模式,估計(jì)有100多種。 軟件設(shè)計(jì)模式太多,就我的理解簡(jiǎn)單說一下最常見的MVC模式。 MVC模式是1996年由Buschmann提出的: 模型(Model):就是封裝數(shù)據(jù)和所有基于對(duì)這些數(shù)據(jù)的操作。 視圖(View):就是封裝的是對(duì)數(shù)據(jù)顯示,即用戶界面。 控制器(Control):就是封裝外界作用于模型的操作和對(duì)數(shù)據(jù)流向的控制等。 另外: RUP(Rational Unified Process)軟件統(tǒng)一過程,XP(Extreme Programming)極端編程,這些通常被叫做“過程方法”,是一種軟件項(xiàng)目實(shí)施過程的方法論,它是針對(duì)軟件項(xiàng)目的實(shí)施過程提出的方法策略。也是另一個(gè)角度的模式。 4.常見的JAVA框架有什么? WAF: 全稱:WEB APPLICATION FRAMEWORK 主要應(yīng)用方面:EJB層,(WEB層也有,但是比較弱)。 主要應(yīng)用技術(shù):EJB等 出處:http://java./blueprints/code/index.html 簡(jiǎn)述:這是SUN在展示J2EE平臺(tái)時(shí)所用的例子PetStore(寵物商店系統(tǒng))里面的框架。是SUN藍(lán)皮書例子程序中提出的應(yīng)用框架。它實(shí)現(xiàn)了 MVC和其他良好的設(shè)計(jì)模式。SUN的網(wǎng)站上有技術(shù)資料,最好下載PetStore來研究,WEBLOGIC里自帶此系統(tǒng),源碼在bea\weblogic700\samples\server\src\petstore。這是學(xué)習(xí)了解J2EE的首選框架。 Struts: 主要應(yīng)用方面:WEB層。 主要應(yīng)用技術(shù):JSP,TagLib,JavaBean,XML等 出處:http://jakarta./struts/index.html 簡(jiǎn)述:這是APACHE的開源項(xiàng)目,目前應(yīng)用很廣泛?;贛VC模式,結(jié)構(gòu)很好,基于JSP。Jbuilder8里已經(jīng)集成了STRUTS1.02的制作。 簡(jiǎn)述WAF+STRUTS結(jié)合的例子:WEB層用STRUTS,EJB層用WAF: JSP(TagLib)??>ActionForm??>Action ??> Event??>EJBAction??>EJB ??>DAO??>Database JSP(TagLib) (forward) <??Action <??EventResponse<?? Turbine: 主要應(yīng)用方面:WEB層。 主要應(yīng)用技術(shù):servlet等 出處:http://jakarta./turbine/index.html 簡(jiǎn)述:這是APACHE的開源項(xiàng)目?;赟ERVLET。據(jù)說速度比較快,基于service(pluggable implementation可插拔的執(zhí)行組件)的方式提供各種服務(wù)。 COCOON: 主要應(yīng)用方面:WEB層。 主要應(yīng)用技術(shù):XML,XSP,servlet等 出處:http://cocoon./2.0/ 簡(jiǎn)述:這是APACHE的一個(gè)開源項(xiàng)目?;赬ML,基于XSP(通俗地說,XSP是在XML靜態(tài)文檔中加入Java程序段后形成的動(dòng)態(tài)XML文檔。)。特點(diǎn)是可以與多種數(shù)據(jù)源交互,包括文件系統(tǒng),數(shù)據(jù)庫(kù),LDAP,XML資源庫(kù),網(wǎng)絡(luò)數(shù)據(jù)源等。 ECHO: 主要應(yīng)用方面:WEB層。 主要應(yīng)用技術(shù):servlet等 出處:http://www./products/echo/ 簡(jiǎn)述:nextapp公司的一個(gè)開源項(xiàng)目?;赟ERVLET。頁(yè)面可以做的很漂亮,結(jié)合echopoint,可以作出很多圖形效果(里面用了jfreechart包)。使用SWING的思想來作網(wǎng)頁(yè),把HTML當(dāng)作JAVA的類來做。但是大量使用Session,頁(yè)面分幀(Frame)很多,系統(tǒng)資源消耗很大。 JATO: 全稱:SUN ONE Application Framework 主要應(yīng)用方面:WEB層。 主要應(yīng)用技術(shù):JSP,TagLib,JavaBean等 出處:http://www./ 簡(jiǎn)述:這是SUN推出的一個(gè)商業(yè)性框架,一看名字就知道是結(jié)合SUN ONE的平臺(tái)推出的。我下載了JATO2.0看了一下,感覺有些簡(jiǎn)單,使用了JSP+TagLib+JavaBean。如他的DOC所說JATO是適合用在小的WEB應(yīng)用里。 TCF: 全稱:Thin-Client Framework 主要應(yīng)用方面:JAVA GUI。 主要應(yīng)用技術(shù):JAVA application等 出處:http://www.alphaworks.ibm.com/tech/tcf 簡(jiǎn)述:這是IBM出的一個(gè)框架?;贛VC模式,基于JAVA Application。推薦一篇介紹文章:http://www-900.ibm.com/developerWorks/cn/java/j-tcf1/index.shtml |
|