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

woaidongmao

文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見(jiàn)諒!~
隨筆 - 1469, 文章 - 0, 評(píng)論 - 661, 引用 - 0
數(shù)據(jù)加載中……

熱點(diǎn)討論:Java編程風(fēng)格的改變

最近Stephan Schmidt在博客中發(fā)表了題為《下一代Java編程風(fēng)格》的文章,闡述了他眼中Java編程風(fēng)格的改變,以及未來(lái)的走向:許多公司和開(kāi)發(fā)人員正在從Java轉(zhuǎn)向其他編程語(yǔ)言:RubyPythonGrrovyErlangScala等等。不過(guò)你可能做不到這一 點(diǎn)。即便如此,你也可以改變你的編程風(fēng)格,獲取這些新語(yǔ)言的優(yōu)勢(shì)。事實(shí)上,在過(guò)去的15年中,Java編程風(fēng)格也已經(jīng)有明顯變化了。

Stephan在文章中提出了以下幾點(diǎn):

  1. 盡可能地標(biāo)注final讓所有東西不可變,把變量標(biāo)為final可以阻止改變它的值。很多時(shí)候,重新為變量賦值會(huì)引入bug,你應(yīng)該使用新的變量。除此之外,final可以提高代碼的可讀性。我針對(duì)這個(gè)話題還寫(xiě)過(guò)一篇文章:《Java中所有變量都應(yīng)該是final
  2. 沒(méi)有setter許多Java程序員會(huì)自然而然地為類中所有的字段加上setter。思考一下,真的每個(gè)字段都需要修改嗎?更好的方法是創(chuàng)建包含改變后狀態(tài)的新對(duì)象。此外,也試著去除getter,我們應(yīng)該遵循Tell, don’t ask的思想。
  3. 避免使用循環(huán)來(lái)操作List從函數(shù)式編程那里獲得的經(jīng)驗(yàn),循環(huán)并不是進(jìn)行集合操作最好方法。例如,我們可以使用Google Collections提供的過(guò)濾功能。
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是一門(mén)繁雜(noisy)的語(yǔ)言,我們應(yīng)該編寫(xiě)更精確的代碼。嘗試將代碼寫(xiě)為一行。例如:
public int add(int a, int b) { return a + b; }
  1. 使用大量接口:領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)已經(jīng)大行其道,一個(gè)應(yīng)該拆分為多種角色,即實(shí)現(xiàn)多種接口,提高復(fù)用程度。方法應(yīng)該面向角色,而不是面向特定的類。我在《不要在Java中使用String》一文中討論了更多這方面的內(nèi)容。
  2. 使用Erlang風(fēng)格的并發(fā):Java的并發(fā)特性(如locksynchronized)過(guò)于低端,難以使用。Erlang風(fēng)格的并發(fā)是一種更好的做法。Java平臺(tái)上已經(jīng)有了AkkaActorom。此外,也可以使用java.util.concurrent中的Join/Fork和數(shù)據(jù)結(jié)構(gòu)進(jìn)行編程。
  3. 使用Fluent InterfaceFluent Interface可以使代碼更短,更容易編寫(xiě)。Google Collections中的MapMaker是個(gè)不錯(cuò)的示例:
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中創(chuàng)建gettersetter如果你擁有簡(jiǎn)單的DTOData Transfer Object),不要耗費(fèi)精力去編寫(xiě)gettersetter,直接使用公開(kāi)的字段吧。不過(guò)在你無(wú)法完全控制代碼的使用情況時(shí),還是小心為上。

這篇文章發(fā)表之后,有許多人發(fā)表了不同的看法。其中Cedric Otaku發(fā)表了文章《下一代Java與現(xiàn)在差不多》予以回應(yīng),其中反對(duì)了Stephan提出的大部分觀點(diǎn)。

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

Cedric的文章之后,Stephan又對(duì)他的說(shuō)法進(jìn)行了補(bǔ)充:

沒(méi)有setter并不代表你不能修改這個(gè)對(duì)象,我只是說(shuō)純粹的setter不是面向?qū)ο蟮乃季S方式。例如,你覺(jué)得stop()setStop(true)哪個(gè)更好一些?

(針對(duì)Predicate代碼不易讀)我認(rèn)為你的假設(shè)有誤。循環(huán)是程序化的代碼,而Predicate是經(jīng)過(guò)封裝的,可以重用的,易于理解的對(duì)象。這里并沒(méi)有函數(shù)式編程,這里是純粹的OO – 我提起FP只是因?yàn)槲覐哪抢?span lang="EN-US">“引入了這個(gè)方式。

還有許多人對(duì)StephonCedric的文章發(fā)表了評(píng)論,例如有人支持Stephan的觀點(diǎn),認(rèn)為final的可以更好的表示出代碼的意圖。甚至有人提出:

更簡(jiǎn)單的解決方案是使用Scala :) – 不可變的狀態(tài)、統(tǒng)一訪問(wèn)原則(字段、屬性、方法看上去一樣)、單行代碼、使用monads或函數(shù)來(lái)替代循環(huán)……這些特性都已經(jīng)在Scala中優(yōu)雅地體現(xiàn)出來(lái)了。

您的Java編程風(fēng)格是什么樣的,和過(guò)去相比有什么改變嗎?

 

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

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产乱码精品一区二区三区不卡| 亚洲午夜一区二区三区| 在线一区二区三区四区五区| 欧美超级免费视 在线| 久久一二三区| 宅男噜噜噜66一区二区| 日韩香蕉视频| 亚洲综合999| 久久精品国产精品亚洲| 免费成人毛片| 先锋影音一区二区三区| 久久精品亚洲精品国产欧美kt∨| 久久久91精品| 亚洲黄一区二区| 在线亚洲+欧美+日本专区| 亚洲欧美国产日韩天堂区| 久久久精品一品道一区| 欧美日韩精品二区第二页| 国产欧美韩日| 91久久精品国产91性色 | 欧美破处大片在线视频| 欧美日韩不卡视频| 国产亚洲成人一区| 亚洲麻豆av| 久久精品国产一区二区三区| 亚洲高清在线视频| 亚洲欧美日韩在线播放| 欧美 日韩 国产一区二区在线视频 | 亚洲自拍偷拍福利| 午夜视频一区| 欧美成人在线免费观看| 一本色道久久加勒比88综合| 久久久99精品免费观看不卡| 欧美日韩www| 一色屋精品视频免费看| 亚洲欧美制服中文字幕| 亚洲欧洲日韩在线| 久久久久国产一区二区三区| 欧美肉体xxxx裸体137大胆| 一区在线观看视频| 欧美一区二区视频观看视频| 最近中文字幕mv在线一区二区三区四区 | 日韩视频欧美视频| 老司机aⅴ在线精品导航| 国产精品久久久久毛片大屁完整版| 亚洲第一网站免费视频| 久久九九久精品国产免费直播| 亚洲乱码国产乱码精品精天堂| 裸体歌舞表演一区二区| 狠狠色丁香婷综合久久| 久久精品亚洲乱码伦伦中文 | 欧美xxx成人| 久久久久久久综合狠狠综合| 国产亚洲精久久久久久| 午夜日韩激情| 亚洲欧美日韩精品综合在线观看 | 亚洲看片网站| 亚洲黄一区二区| 欧美精品在线极品| 亚洲天堂成人在线视频| 亚洲麻豆国产自偷在线| 欧美日韩另类在线| 亚洲一区三区电影在线观看| 一区二区三区日韩| 国产精品极品美女粉嫩高清在线 | 亚洲欧美日韩区| 国产精品扒开腿做爽爽爽软件| 亚洲裸体在线观看| 99国产精品视频免费观看| 欧美日韩亚洲视频| 亚洲欧美日韩另类| 亚洲欧美电影院| 韩国女主播一区| 欧美激情一区二区三区蜜桃视频| 欧美成人午夜激情在线| 日韩午夜av在线| 亚洲亚洲精品在线观看| 国产偷国产偷亚洲高清97cao| 久久久久九九九| 欧美不卡一卡二卡免费版| 一区二区欧美视频| 先锋影音久久| 亚洲人成绝费网站色www| 一本色道久久88综合日韩精品| 国产美女精品视频| 欧美激情亚洲国产| 国产精品嫩草99a| 美女黄色成人网| 欧美日韩综合一区| 浪潮色综合久久天堂| 欧美激情一区二区在线| 欧美一区二区三区视频在线观看| 久久久久九九九九| 亚洲一区精品在线| 老司机午夜精品| 性欧美1819sex性高清| 男男成人高潮片免费网站| 欧美亚洲系列| 欧美另类69精品久久久久9999| 欧美一区在线直播| 欧美理论电影网| 欧美3dxxxxhd| 国产日韩欧美不卡| 99国产精品视频免费观看一公开| 激情综合自拍| 亚洲欧美一区二区原创| 夜夜嗨av一区二区三区四区| 欧美一区二区三区的| 一区二区三区免费看| 老巨人导航500精品| 久久久久久久97| 国产精品日日做人人爱| 亚洲三级网站| 亚洲日本激情| 久久午夜激情| 久久天天躁狠狠躁夜夜av| 国产精品九色蝌蚪自拍| 亚洲免费电影在线| 99精品99| 欧美精品久久久久久久免费观看| 麻豆精品网站| 红桃视频一区| 久久精品亚洲乱码伦伦中文| 先锋影音国产一区| 国产精品视频导航| 亚洲午夜av| 香港久久久电影| 国产精品日韩欧美一区| 在线亚洲自拍| 欧美在线视频一区| 久久躁狠狠躁夜夜爽| 亚洲欧美日韩国产综合在线 | 国产精品色婷婷| 日韩视频在线观看| 99re热精品| 欧美日韩一区二区三区在线| 91久久久久久国产精品| 日韩天天综合| 欧美日韩视频在线一区二区观看视频 | 在线观看亚洲视频| 久久频这里精品99香蕉| 免费看的黄色欧美网站| 亚洲第一综合天堂另类专| 久久综合九色99| 亚洲国产精品成人综合| 日韩视频一区| 欧美性视频网站| 午夜精品久久久久久99热软件| 久久精品99国产精品| 国语自产在线不卡| 美女网站久久| 亚洲精品一区二区三区在线观看| 一区二区免费看| 国产精品永久| 久久综合九色九九| 99国产精品国产精品久久| 国产精品99久久久久久久vr | 亚洲福利视频三区| 欧美精品v日韩精品v国产精品| 日韩视频免费| 久久久久久91香蕉国产| 亚洲欧洲偷拍精品| 国产精品久久久免费| 欧美专区第一页| 91久久国产综合久久| 午夜宅男久久久| 亚洲国产黄色| 国产精品男gay被猛男狂揉视频| 久久国产福利国产秒拍| 亚洲国产婷婷| 欧美一区二区女人| 亚洲美女精品一区| 国产亚洲精品久久久| 欧美精品久久久久久久| 欧美一区二区免费| 99国产一区| 欧美成人自拍视频| 欧美专区在线| 亚洲图片欧洲图片日韩av| 狠狠色2019综合网| 国产精品久久久久秋霞鲁丝| 欧美大学生性色视频| 欧美在线观看视频| 99视频精品免费观看| 美女日韩在线中文字幕| 性8sex亚洲区入口| 亚洲一区久久久| 亚洲精品乱码久久久久久蜜桃麻豆 | 91久久精品日日躁夜夜躁欧美| 欧美理论片在线观看| 亚洲国产高清在线| 久久久精品日韩| 亚洲自拍电影| 日韩一二三区视频| 在线欧美小视频| 国产亚洲欧美日韩一区二区| 欧美日韩在线观看视频| 免费观看亚洲视频大全| 久久狠狠一本精品综合网| 亚洲一区国产精品|