隨筆 - 115  文章 - 481  trackbacks - 0
          <2007年8月>
          2930311234
          567891011
          12131415161718
          19202122232425
          2627282930311
          2345678

          常用鏈接

          留言簿(19)

          隨筆檔案(115)

          文章檔案(4)

          新聞檔案(1)

          成員連接

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

            只要你愿意,嚴(yán)肅規(guī)矩的java也同樣可以變得“動態(tài)”靈活起來。動有動的好處,靜有靜的好處。俗話說得好,“沒有規(guī)矩不成方圓”,但“生命誠可貴,愛情價更高,若為自由幫,兩者皆可拋”。那么作為忙碌在程序藝術(shù)世界里的子民們,我們何去何從呢?投奔動態(tài)語言陣營還是繼續(xù)在四平八穩(wěn)的Java領(lǐng)域奮戰(zhàn)? 在我看來,“動”或“不動”需要一個黃金分割點。

          1、尋找“動”與“不動”的黃金分割點

             兩年前,以Martin Fowler為代表的一群大師們突然集體投奔到了動態(tài)語言陣營,手持RoR這個“核武器”,大喊著要滅了Java,要取代Java。現(xiàn)在回頭來看,動態(tài)語言給我們確實帶來了一些的革命性的思想,但同時我們也發(fā)現(xiàn)被大師們忽悠了一把。
            對于強(qiáng)類型的Java語言來說,與真正的動態(tài)語言比起來,確實要受限制很多。在我看來,借某位大師的比喻,Ruby的敏捷相當(dāng)草書,而java就是正楷。用Ruby,十個程序員寫出來的程序就是十種風(fēng)格,這跟我們寫文章是一樣的。而Java就是規(guī)規(guī)矩矩宋體方塊字,橫是橫,豎是豎,先寫哪一筆后寫哪一劃,一切都是規(guī)定好了的。強(qiáng)類型的靜態(tài)語言從語法的底層就建立了一套較為穩(wěn)固的規(guī)則體系,因此更加規(guī)范,從長遠(yuǎn)來說,或者是對于大型項目來說,肯定是有規(guī)范并且規(guī)范嚴(yán)格的,較之規(guī)范不嚴(yán)格的表現(xiàn)起來從擴(kuò)展性、可維護(hù)性等要優(yōu)秀得多。
            動態(tài)語言與強(qiáng)類型的靜態(tài)語言,他們各有自己的特長范圍。在企業(yè)級應(yīng)用領(lǐng)域,JavaEE的優(yōu)勢不是一天兩天建立起來的。而動態(tài)語言其實由來已久,最優(yōu)秀我覺得應(yīng)該算是javascript了,想想以前用asp寫程序,服務(wù)器及客戶端腳本都用的js,對于小型的應(yīng)用來說,確實很舒服。而近兩年由于Ajax概念股的走紅,javascript更加春風(fēng)得意,prototype.js等一批的Ajax框架及引擎更是把javascript的OO及動態(tài)特性發(fā)揮到極致。對于來勢兇猛的RoR來說,在我看來最好先去跟php、Python這種同類的競爭者好好PK幾年,如果不被他們滅掉的話,然后再來研究要“花多少光年來滅掉java”這樣的命題。
            對于小型的應(yīng)用來說,小巧、靈活、簡單的動態(tài)語言,肯定在先機(jī)上占有一定優(yōu)勢。但對于大型的企業(yè)級應(yīng)用來說,動態(tài)語言的這種巧、活、隨意性恰好成為其劣勢。這其中的原因除了本身能力(多核、線程、系統(tǒng)資源等)有限以外,太“草”了也是限制其發(fā)展的原因。事實證明,動態(tài)語言能做到的,咱們靜態(tài)語言稍為動動腦子調(diào)整一下也能做到,比如Groovy;而靜態(tài)語言能做到的,動態(tài)語言打死也做不到,除非他自己變成靜態(tài)的強(qiáng)類型語言,比如多核線程、二階段分布式事務(wù)。如果做到了,他可能就不僅僅是動態(tài)語言了。
            動有動的好處,靜有靜的好處。俗話說得好,“沒有規(guī)矩不成方圓”,但“生命誠可貴,愛情價更高,若為自由幫,兩者皆可拋”。那么作為忙碌在程序藝術(shù)世界里的子民們,我們何去何從呢?投奔動態(tài)語言陣營還是繼續(xù)在四平八穩(wěn)的Java領(lǐng)域奮戰(zhàn)?
            在我看來,“動”或“不動”需要一個黃金分割點。而在EasyJWeb之所以提供一些“動態(tài)”特性的支持,也就是尋找這樣一個分割點而做的,把動與靜的好處進(jìn)行分析、權(quán)衡,然后讓JavaEE應(yīng)用開發(fā)變得更加的容易。努力尋找這樣的黃金分割點,對一些非常好的動態(tài)特性及思想提供應(yīng)用級的支持,而對于一些必須規(guī)范才能產(chǎn)生效率的特性,則堅持推廣應(yīng)用。Java社區(qū)中的很多人都在為尋找這個分割點而努力。Java本身也已經(jīng)意識到這一點,在其新的版本中都增加了對一些優(yōu)秀的動態(tài)語言特性的支持。
           當(dāng)然,對一直覺得“受約束、受限制”的我們來說,能“動”一點、想“草”的時候“草”兩下,這是一件非常快樂的事兒。因此,EasyJWeb在基于Java這樣一個具有規(guī)范的平臺及環(huán)境作為基礎(chǔ)的前提下,做了一些工作,使得我我們在一定的范圍內(nèi)也可以靈活的“動”起來,隨性地“草”起來,這樣使得我們可以放開手腳、輕松大膽的往前走。下面我通過一些例子來說明。

          2、百變CmdAction-AbstractCmdAction
            在EasyJWeb-.10新版本的Command類型的Action基類即AbstractCmdAction中,提供了足夠的靈活特性使你得可以像使密宗拳一樣書寫Java Web Action。可以根據(jù)你不同的應(yīng)用場景,像用動態(tài)語言那樣書寫Action中的command。
            假如我們在一個模塊中要執(zhí)行一個名為create操作,下面的方法簽名都是合法的:

          public Page doCreate(WebForm form,Module module)
          public Page doCreate(WebForm form)
          public Page doCreate(Module module)
          public Page doCreate();
          public void doCreate(WebForm form,Module module)
          public void doCreate(WebForm form)
          public void doCreate(Module module)
          public void doCreate();


          另外,把方法名稱改成create,系統(tǒng)也一樣能識別。如:

          public Page create(WebForm form,Module module)
          public Page create(WebForm form)
          public Page create(Module module)
          public Page create();
          public void create(WebForm form,Module module)
          public void create(WebForm form)
          public void create(Module module)
          public void create();

             我們可以使用xxx.ejf?easyJWebCommand=create的方式來調(diào)用這個方法,也可以使用xxx.ejf?cmd=create的方式來調(diào)用,甚至我們還可以使用/ejf/xxx/create的形式來調(diào)用。

            這種靈活的Action中的命名方法,一方面可以使代碼更加簡潔,易維護(hù),同時也使我們的代碼看起來更cool。另外一個主要原因是其使我們可以非常容易書寫這些方法的測試代碼,不需要任何Web容器,我們就能運(yùn)行EasyJWeb的單元測試。

            看看Struts那種每個方法都必須生搬硬套的生成下面的方法:

          public ActionForward command(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) {

          }


            對照EasyJWeb中提供的百變Command方法簽名,您是否感覺到這個世界正在前進(jìn)呢?
          3、更多的“動感”地帶
            想動就動起來吧,不僅僅體現(xiàn)在方法的書寫方式上。在EasyJWeb中很多地方都用到了這種“動態(tài)”的特性,比如forward及go方法提供的多種調(diào)用方法,驗證標(biāo)簽中以自然語言為主體的動態(tài)參數(shù)配置信息,都體現(xiàn)了EasyJWeb能“動起來”的特性。
            以驗證為例,我們可以通過多種方式來告訴EasyJWeb我們需要進(jìn)行驗證。比如我可以通過在@FormPO中針對一個或多個屬性指定驗證規(guī)則,看示例:

          @FormPO(name="person",validators={@Validator(name="required",field="name,sex,heigth,borndate"),@Validator(name="range",field="borndate",value="min:1908-01-01;max:2008-01-01")})
          public class Person{
          …屬性及getter
          /setter方法
          }


            你應(yīng)該猜得出來,上面的標(biāo)簽中我們指定Person對象的name,sex,heigth,borndate等屬性為必填屬性。在驗證數(shù)據(jù)范圍的RangeValidator中,你可以不用去管要驗證的目標(biāo)類型是Integer還是BigDecimal或者是Date,只要他能比較,就可以應(yīng)用該驗證器來對其值范圍進(jìn)行驗證,確保我們的域模型得到的是一個合理的值。
            在標(biāo)識驗證的時候,可以設(shè)置自定義的驗證提示信息。比如你可以使用下面的方式來標(biāo)識一個范圍驗證:
          @Validator(name="range",field="borndate",value="min:1908-01-01;max:2008-01-01;min_msg:出生日期不能小于1908年;max_msg:出生日期不能大于2008年!")
            除了min_msg及max_msg以外,你還可以使用基于java習(xí)慣的minMsg及maxMsg來標(biāo)識同樣的驗證提示信息。

          posted on 2007-08-17 09:18 簡易java框架 閱讀(1011) 評論(4)  編輯  收藏

          FeedBack:
          # re: java也能“動”起來  2007-08-17 12:43 beans
          前面分析得很精彩,easyjweb沒用過,不太好評價。  回復(fù)  更多評論
            
          # re: java也能“動”起來  2007-08-17 14:29 itkui
          文章寫的很出彩,呵呵!  回復(fù)  更多評論
            
          # re: java也能“動”起來 [未登錄] 2007-08-18 07:52 z
          對于來勢兇猛的RoR來說,在我看來最好先去跟php、Python這種同類的競爭者好好PK幾年,如果不被他們滅掉的話,然后再來研究要“花多少光年來滅掉java”這樣的命題。  回復(fù)  更多評論
            
          # re: java也能“動”起來  2007-08-20 09:15 DBS
          這幾天下載了easyjweb框架,學(xué)習(xí)了一下。感覺很不錯,第一次看到國產(chǎn)開源MVC中做得這么好的  回復(fù)  更多評論
            

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 桦甸市| 万州区| 星座| 栾川县| 宽甸| 皋兰县| 亚东县| 喀喇沁旗| 黔南| 本溪市| 通州市| 通江县| 靖边县| 博乐市| 太和县| 浏阳市| 三原县| 宁强县| 株洲县| 抚州市| 万载县| 石景山区| 台中市| 武定县| 九台市| 新河县| 平顶山市| 江都市| 秦安县| 绥棱县| 西宁市| 鱼台县| 阿图什市| 郓城县| 雅安市| 山西省| 卓资县| 武鸣县| 洞口县| 米易县| 云浮市|