• <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>

            woaidongmao

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

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

            最近Stephan Schmidt在博客中發表了題為《下一代Java編程風格》的文章,闡述了他眼中Java編程風格的改變,以及未來的走向:許多公司和開發人員正在從Java轉向其他編程語言:RubyPythonGrrovyErlangScala等等。不過你可能做不到這一 點。即便如此,你也可以改變你的編程風格,獲取這些新語言的優勢。事實上,在過去的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 肥仔 閱讀(360) 評論(0)  編輯 收藏 引用 所屬分類: Web-后臺

            久久久久亚洲AV成人网人人网站| 久久久久人妻一区二区三区| 久久中文娱乐网| 国产精品伦理久久久久久| 夜夜亚洲天天久久| 无码乱码观看精品久久| 久久久久久久97| 久久久久久综合一区中文字幕 | 久久久久亚洲av综合波多野结衣| 99久久精品免费看国产一区二区三区| 熟妇人妻久久中文字幕| 国产亚州精品女人久久久久久 | 久久不见久久见免费视频7| 久久久久久a亚洲欧洲aⅴ| 久久99国产精品成人欧美| 欧美亚洲国产精品久久| 97精品国产97久久久久久免费 | 99精品久久久久久久婷婷| 狠狠色婷婷久久综合频道日韩| 久久精品国产福利国产秒| 热久久视久久精品18| 亚洲午夜久久影院| 久久精品国产亚洲AV大全| 国产69精品久久久久观看软件 | 亚洲精品白浆高清久久久久久| 久久精品国产一区二区三区不卡| 无遮挡粉嫩小泬久久久久久久| 久久久99精品成人片中文字幕 | 久久综合给合久久狠狠狠97色| 久久久久久久综合日本| 久久国产精品99久久久久久老狼| 伊人久久大香线蕉AV色婷婷色| 亚洲欧美成人久久综合中文网 | 久久精品麻豆日日躁夜夜躁| 中文字幕亚洲综合久久菠萝蜜| 久久精品无码一区二区日韩AV | 久久久久av无码免费网| 久久青青草视频| 久久久久亚洲AV成人网人人网站 | 色综合久久久久综合体桃花网| 亚洲七七久久精品中文国产|