青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

woaidongmao

文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
數據加載中……

熱點討論:Java編程風格的改變

最近Stephan Schmidt在博客中發表了題為《下一代Java編程風格》的文章,闡述了他眼中Java編程風格的改變,以及未來的走向:許多公司和開發人員正在從Java轉向其他編程語言:Ruby、Python、Grrovy、ErlangScala等等。不過你可能做不到這一 點。即便如此,你也可以改變你的編程風格,獲取這些新語言的優勢。事實上,在過去的15年中,Java編程風格也已經有明顯變化了。

Stephan在文章中提出了以下幾點:

  1. 盡可能地標注final讓所有東西不可變,把變量標為final可以阻止改變它的值。很多時候,重新為變量賦值會引入bug,你應該使用新的變量。除此之外,final可以提高代碼的可讀性。我針對這個話題還寫過一篇文章:《Java中所有變量都應該是final
  2. 沒有setter許多Java程序員會自然而然地為類中所有的字段加上setter。思考一下,真的每個字段都需要修改嗎?更好的方法是創建包含改變后狀態的新對象。此外,也試著去除getter,我們應該遵循Tell, don’t ask的思想。
  3. 避免使用循環來操作List從函數式編程那里獲得的經驗,循環并不是進行集合操作最好方法。例如,我們可以使用Google Collections提供的過濾功能。
4.           Predicate canDrinkBeer = new Predicate() {
5.                public boolean apply(HasAge hasAge) {
6.                    return hasAge.isOlderThan( 16 );
7.               }
8.           };
9.            
List<Person> beerDrinkers = filter(persons, canDrinkBeer);
  1. 使用單行代碼:Java是一門繁雜(noisy)的語言,我們應該編寫更精確的代碼。嘗試將代碼寫為一行。例如:
public int add(int a, int b) { return a + b; }
  1. 使用大量接口:領域驅動設計已經大行其道,一個應該拆分為多種角色,即實現多種接口,提高復用程度。方法應該面向角色,而不是面向特定的類。我在《不要在Java中使用String》一文中討論了更多這方面的內容。
  2. 使用Erlang風格的并發:Java的并發特性(如locksynchronized)過于低端,難以使用。Erlang風格的并發是一種更好的做法。Java平臺上已經有了AkkaActorom。此外,也可以使用java.util.concurrent中的Join/Fork和數據結構進行編程。
  3. 使用Fluent InterfaceFluent Interface可以使代碼更短,更容易編寫。Google Collections中的MapMaker是個不錯的示例:
14.       ConcurrentMap graphs = new MapMaker()
15.           .concurrencyLevel(32)
16.           .softKeys()
17.           .weakValues()
18.           .expiration(30, TimeUnit.MINUTES)
19.           .makeComputingMap(
20.               new Function() {
21.                   public Graph apply(Key key) {
22.                       return createExpensiveGraph(key);
23.                   }
        });
  1. 避免在DTO中創建gettersetter如果你擁有簡單的DTOData Transfer Object),不要耗費精力去編寫gettersetter,直接使用公開的字段吧。不過在你無法完全控制代碼的使用情況時,還是小心為上。

這篇文章發表之后,有許多人發表了不同的看法。其中Cedric Otaku發表了文章《下一代Java與現在差不多》予以回應,其中反對了Stephan提出的大部分觀點。

  • 盡可能final太多final會降低代碼的可讀性,它無法代碼額外的好處。我已經不記得上次因為重新給變量賦值而造成錯誤是什么時候了。值得一提的是,在字段以外的成員上標記final違反了Google的風格指南。
  • 避免setter看上去不錯,不過這不現實。有些時候你不愿把所有的參數都通過構造函數傳入。此外,如果使用對象池的時候,可變的對象會讓編程更為方便。Stephan不是第一個提出要將訪問器(accessor)從OO編程中移除的人,不過這個說法很明顯不可行
  • 避免循環:Java并不適合函數式編程風格,所以我認為使用Predicate的代碼反而難以讀懂。我估計大部分的Java程序員會同意我的觀點,即使他們已經熟悉了閉包風格。
  • 單行代碼:這要視情況而定。并引入臨時變量把一個表達式拆開可以提高代碼可讀性,也容易為其設置斷點。
  • 使用接口:不錯的建議,但也不能過火。過去我也爭論過類似的話題,不過引入太多接口會導致細小類型的爆炸,使你高端的類型意圖變得模糊。
  • Erlang風格并行:重申一點,使用Java設計以外的編程風格是危險的做法。java.util.concurrent中包含了非常有用的功能,我遇到過不少基于這些元素的Java抽象,它們要優于Erlang風格的actor架構。
  • Fluent Interface這個建議比較有趣,它與Stephan提出的另一個建議避免setter”相違背。Fluent Interface制式setter的另一種形式,不是嗎?
  • 使用公有字段:不,千萬別這么做。你不會因為加了訪問器而后悔,但是我能保證你會因為一時偷懶,使用了公有字段而后悔莫及。

Cedric的文章之后,Stephan又對他的說法進行了補充:

沒有setter并不代表你不能修改這個對象,我只是說純粹的setter不是面向對象的思維方式。例如,你覺得stop()setStop(true)哪個更好一些?

(針對Predicate代碼不易讀)我認為你的假設有誤。循環是程序化的代碼,而Predicate是經過封裝的,可以重用的,易于理解的對象。這里并沒有函數式編程,這里是純粹的OO – 我提起FP只是因為我從那里引入了這個方式。

還有許多人對StephonCedric的文章發表了評論,例如有人支持Stephan的觀點,認為final的可以更好的表示出代碼的意圖。甚至有人提出:

更簡單的解決方案是使用Scala :) – 不可變的狀態、統一訪問原則(字段、屬性、方法看上去一樣)、單行代碼、使用monads或函數來替代循環……這些特性都已經在Scala中優雅地體現出來了。

您的Java編程風格是什么樣的,和過去相比有什么改變嗎?

 

posted on 2009-08-19 11:53 肥仔 閱讀(369) 評論(0)  編輯 收藏 引用 所屬分類: Web-后臺

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产丝袜一区二区三区| 欧美专区日韩视频| 欧美视频一区二区在线观看| 久久久午夜电影| 亚洲欧美日韩精品在线| 亚洲欧美国产制服动漫| 欧美一区二区三区四区在线观看地址| 一区二区三区久久网| 亚洲欧美激情视频| 久久精品最新地址| 欧美国产一区二区| 国产精品免费网站| 亚洲国产裸拍裸体视频在线观看乱了中文 | 久久久夜夜夜| 亚洲高清不卡av| 亚洲一区二区三区高清不卡| 亚洲一区激情| 欧美伦理a级免费电影| 国产亚洲在线| 亚洲一级在线观看| 欧美日韩免费网站| 在线观看欧美| 午夜在线视频观看日韩17c| 欧美成人第一页| 久久久精彩视频| 日韩视频一区二区| 在线综合亚洲欧美在线视频| 伊人久久大香线蕉综合热线| 国产精品理论片在线观看| 亚洲永久免费观看| 男同欧美伦乱| 久久久久国产精品人| 亚洲欧美激情诱惑| 国产日韩欧美日韩大片| 久久久免费观看视频| 中文亚洲字幕| 欧美三级电影网| 亚洲第一搞黄网站| 欧美成人一区二区三区片免费| 午夜精品久久久久久久99水蜜桃| 国产精品人人做人人爽人人添| 亚洲视频一区在线| 一区二区三区视频在线| 欧美人与性动交a欧美精品| 国语自产精品视频在线看抢先版结局| 久久亚洲国产成人| 在线欧美一区| 欧美一区二区三区另类| 牛夜精品久久久久久久99黑人| 亚洲国产精品va| 亚洲欧美另类在线| 亚洲国产成人在线视频| 国产精品看片你懂得| 亚洲欧美精品在线观看| 欧美夜福利tv在线| 一本不卡影院| 老**午夜毛片一区二区三区| 99在线精品视频在线观看| 久久精品国产亚洲精品| 亚洲图片你懂的| 欧美精品二区| 久久久久久亚洲综合影院红桃 | 国产乱子伦一区二区三区国色天香 | 精品99一区二区三区| 亚洲一区黄色| 久久久久久久性| 亚洲高清在线精品| 美女尤物久久精品| 亚洲欧洲一区二区天堂久久| 亚洲激精日韩激精欧美精品| 99精品视频免费观看| 黄色一区二区三区四区| 国产精品99久久久久久久久 | 欧美日韩国产美| 牛夜精品久久久久久久99黑人 | 亚洲欧美日韩人成在线播放| 亚洲日本成人女熟在线观看| 久久久青草婷婷精品综合日韩| 久久精品亚洲一区二区三区浴池| 国产精品三区www17con| 亚洲视频在线观看| 久久免费精品视频| 日韩亚洲在线| 国产麻豆精品视频| 模特精品在线| 亚洲视频在线观看| 欧美激情一区三区| 亚洲欧美日韩精品| 91久久国产精品91久久性色| 欧美日韩精品免费观看视一区二区| 99国产精品久久久久久久| 久久精品成人一区二区三区| 亚洲国产精品久久人人爱蜜臀 | 欧美精品v日韩精品v国产精品| 亚洲精品一区二区三区福利| 久久av最新网址| 一区二区三区免费看| 在线观看亚洲精品| 国产日韩一区二区三区| 欧美精品一区二区三区在线播放| 亚洲主播在线观看| 99视频有精品| 一区二区电影免费在线观看| 欧美激情 亚洲a∨综合| 欧美福利一区二区| 免费日韩成人| 欧美高清在线视频观看不卡| 久久日韩粉嫩一区二区三区 | 欧美成人免费在线观看| 亚洲在线国产日韩欧美| 亚洲国产成人在线| 久久久久久久一区| 欧美在线观看网址综合| 欧美日韩精品一区视频| 一区二区av在线| 久久国产精品99久久久久久老狼| 国产日韩欧美一区二区三区在线观看 | 欧美在线精品一区| 欧美激情综合| 美女脱光内衣内裤视频久久网站| 性欧美大战久久久久久久免费观看 | 亚洲婷婷综合久久一本伊一区| 国产伦精品一区二区三区| 国产午夜精品全部视频在线播放| 欧美精品久久久久久久久老牛影院| 午夜视频在线观看一区二区| 亚洲精品乱码久久久久久蜜桃麻豆| 亚洲电影免费在线观看| 亚洲精品乱码久久久久| 国产精品久久久久久模特| 欧美国产日本高清在线| 欧美午夜www高清视频| 欧美人体xx| 国产日本欧美一区二区三区在线| 国产精品一区在线观看你懂的| 欧美视频免费| 国语自产精品视频在线看抢先版结局| 韩国成人福利片在线播放| 亚洲一区二区三区在线观看视频| 国产自产女人91一区在线观看| 一本色道久久综合亚洲精品不| 国内外成人在线| 午夜精品电影| 欧美在线播放视频| 国产乱肥老妇国产一区二 | 欧美午夜一区二区福利视频| 亚洲欧洲视频在线| 亚洲美洲欧洲综合国产一区| 欧美极品在线观看| 一本色道久久综合亚洲精品不| 亚洲无玛一区| 国产精品一区二区三区成人| 香蕉av福利精品导航| 久久免费一区| 亚洲啪啪91| 欧美日韩理论| 午夜视黄欧洲亚洲| 美女精品视频一区| 亚洲精品四区| 国产精品久久77777| 久久不见久久见免费视频1| 欧美成人日韩| 亚洲综合电影| 怡红院精品视频| 欧美福利网址| 在线亚洲激情| 欧美a级在线| 亚洲一二三区精品| 黄色在线一区| 欧美午夜视频网站| 久久综合导航| 亚洲欧美久久久久一区二区三区| 欧美不卡激情三级在线观看| 亚洲图片在区色| 精品99一区二区三区| 欧美日韩久久精品| 久久精品夜色噜噜亚洲a∨ | 国产精品亚洲产品| 久久综合影音| 亚洲香蕉网站| 欧美成人精品| 久久精品国产精品亚洲精品| 91久久精品日日躁夜夜躁欧美| 国产精品乱码妇女bbbb| 女女同性精品视频| 欧美一区二区三区免费视频| 亚洲精品国产精品国自产观看浪潮| 亚洲欧美在线aaa| 亚洲日本中文字幕| 娇妻被交换粗又大又硬视频欧美| 欧美性猛交xxxx乱大交蜜桃| 久久综合久久久久88| 性亚洲最疯狂xxxx高清| 一区二区三区久久网| 亚洲福利精品| 农夫在线精品视频免费观看| 久久激情五月婷婷| 羞羞答答国产精品www一本| 日韩小视频在线观看| 亚洲缚视频在线观看|