• <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>
            隨筆-19  評論-21  文章-0  trackbacks-0
            自動化法則

                計算機原本就該從事簡單重復的工作。只要把任務指派給它們,它們就可以一遍又一遍毫不走樣地重復執行,而且速度很快。但卻經常看見一種奇怪的現象:人們在計算機上手工做一些簡單重復的工作,計算機則在大半夜里扎堆閑聊取笑這些可憐的用戶。

                我們應該利用作為程序員的優勢,看到普通用戶無法看到的東西,培養larry所說的“懶惰,急躁和傲慢”讓計算機高效地為我們工作:命令行是如此地高效,腳本是如此地方便,銜接兩個小工具能達到如此神奇的效果。。。

            古代哲人

            1. 亞里斯多德的“事物本質性質和附屬性質”理論:致力本質復雜性,去除附屬復雜性。你現在想解決問題A,在解決A的問題中遇到了問題B,接著你去解決問題B,戲劇性的是你遇到了很多接二連三的問題C,D,E,或者在很多年后,程序才出現問題C,D,E,可是你的最初問題是A,不是嗎?B,C,D等等都是附屬性質,當這些附屬性質越來越多,越來越復雜的時候,也是開始思考另一個解決A的辦法的時候了。(如果作為學習,可以試著去解決那些附屬性質)

            2. 笛米特法則:任何一個對象或者方法,它應該只能調用下列對象:該對象本身,作為參數傳遞進來的對象,在方法內創建的對象。這么做的主要目的是信息隱藏,同時使類的耦合更加松散。

            3. “古老”的軟件傳說。了解歷史才能更好地創造歷史。讀讀那些“古老”的“寶典”(如《程序員修煉之道》《人月神話》《Smalltalk Best Practice Patterns》),會學到很多有用的東西,或許你會發出一生驚嘆。“當你的老板要求你使用一個低質量的代碼庫時,不需要在崩潰中咬牙切齒,告訴他:你正“站在侏儒的肩膀”上的陷阱中,然后他就會明白不僅僅只有你才覺得那是個壞主意。”

            擁抱多語言編程

               “每個語言都有自己擅長的地方”(我的想法)。比如perl特別適合文本處理,用來處理網頁也很好(畢竟有些從服務器上返回的數據就是用perl返回的,所以用perl也會比較合適)。

                計算機語言就像鯊魚,要是保持靜止就會死。

                Java的創造都們實際上創造了兩樣東西:Java語言和Java平臺。后者就是我們擺脫歷史包袱的途徑(Java語言的特性包含了一些它本該可以忽略的東西,如Java程序初始化的順序和從0開始的數組)。讀到本文我才開始理解平臺的深刻意義。

                舉兩個例子(Groovy和Jaskell)說明。

                Groovy是一種開源的編程語言,它給Java帶來了動態語言的語法和功能,它會生成Java字節碼,因此可以在Java平臺上運行。在Java之后十多年里浮現出來的各種語言很大程序上影響著Groovy的語法:Groovy支持裝飾,較松散的類型系統,“理解”迭代的集合,以及很多現代編程語言的改進特性。而且它可以編譯成純正的Java字節碼。用Groovy寫成的代碼簡潔且并不比用Java寫的代碼效率低多少,而且能充分借用Java平臺的優勢。

                Jaskell是運行在Java平臺上的Haskell版本。Jaskell擁有函數式程序設計語言的優勢:函數不改變外界的狀態,純粹的函數式語言壓根沒有“變量”概念;函數式語言對多線程的支持比命令式語言要強得多,用函數式語言更容易寫出強壯的線程安全的代碼,對并發支持也比較好(我想這是Erlang流行的原因)。同時Jaskell也能借用Java平臺的優勢。

                 Java平臺借用這些多語言特性,一定會走得更好,走得更遠。不過,在帶來好處的同時,也帶來了一個問題:多語言應用程序更難高度,解決這個問題最簡單的辦法也跟現在一樣:靠嚴格的單元測試來避免在調試器上浪費時間。

                 多語言開發風格會把我們帶向領域特定語言(Domain-specific Language,DSL)。我們會以一些專門的語言為基礎,創造出非常有針對性的,非常專注某一問題域的DSL。抱定一種通用語言不放的年代就快結束了,我們正在進入一個專業細分的新時代。大學時代的Haskell教材還在書架頂上蒙塵嗎?該給它撣撣灰了。

                 ps: 我們也可以以C++為基礎,來創造一種DSL,思考。



            鏈接: 卓有成效的程序員




            posted on 2010-07-10 12:40 hex108 閱讀(851) 評論(4)  編輯 收藏 引用 所屬分類: Read the book

            評論:
            # re: 卓有成效的程序員 2010-12-03 02:05 | flagman
            使用C++ template metaprogramming,不就可以定義DSL嗎?

            只是這樣的實現,目前的問題是還沒有辦法保證定義出的DSL是type-safe的。  回復  更多評論
              
            # re: 卓有成效的程序員 2010-12-03 15:32 | hex108
            @flagman

            呵呵,你說的問題是存在的(這個問題我再仔細想想。。。), 3Q ~
            相對于卓有成效的程序員(http://ishare.iask.sina.com.cn/f/10584969.html)里提供的關于DSL例子 ,我更喜歡《程序員修煉之道》(http://forum.eviloctal.com/thread-33274-1-1.html)第二章12節領域語言 對 DSL的應用。 我這里說的DSL也是想側重于“新發明”一種小的語言,在這個小語言里,一條簡單的語句能執行復雜的功能,讓抽像層次更高,比如:sendMail(from,to,content)為發email的函數, 這樣我們就可以直接調用sendMail了(感覺好像是提供了庫函數了。。。)。  回復  更多評論
              
            # re: 卓有成效的程序員 2011-10-19 19:13 | high PR Backlinks
            thanks for it.  回復  更多評論
              
            久久国产免费| 91精品国产色综久久| 国产成人综合久久精品尤物| 久久综合给久久狠狠97色| 久久久久久免费视频| 亚洲美日韩Av中文字幕无码久久久妻妇 | 国内精品欧美久久精品| 99久久精品国产免看国产一区| 久久国产精品成人片免费| 久久香综合精品久久伊人| 久久综合久久自在自线精品自 | 国产精品久久久久久影院| 国产精品久久久久9999高清| 国产欧美久久久精品| 国产精品久久久99| 久久99精品久久久久久齐齐| 久久精品人妻一区二区三区| 色偷偷91久久综合噜噜噜噜| 久久综合视频网| 国产精品久久久久国产A级| 99久久精品国产麻豆| 狠狠精品久久久无码中文字幕 | 久久频这里精品99香蕉久| 久久婷婷是五月综合色狠狠| 老色鬼久久亚洲AV综合| 狠狠色丁香婷婷综合久久来| 久久人人爽人爽人人爽av| 久久久久久久女国产乱让韩| 国产成人久久精品激情| 久久伊人五月天论坛| 人妻精品久久久久中文字幕一冢本| 国产精品久久久久影院嫩草| 久久精品亚洲福利| 久久夜色精品国产欧美乱| 久久综合丁香激情久久| 久久久久久综合网天天| 国内精品久久久久影院网站| 婷婷伊人久久大香线蕉AV| 久久久艹| 一级做a爰片久久毛片16| 99精品久久久久久久婷婷|