<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    冒號和他的學生們(連載18)——系統語言

    冒號和他的學生們

    ——程序員提高班紀事

    18.系統語言

    居高者形逸而神勞,處下者形勞而神逸                        —《洪應明·菜根譚》


    問號忙問:“您打算比較哪些主流語言呢?”

    冒號回答:“就談談第一堂課提到的最流行的十二種語言吧。按語法特征可將它們分為三類:C族靜態語言五種——CC++JavaC#D;非C族靜態語言兩種——VBDelphi;動態語言五種——PerlPHPPythonRuby JavaScript 。”

    嘆號表示懷疑:“這么多種語言怎么比較得過來?”

    冒號解釋:“我們主要比較第一類的C族語言,這些也是今后學習的重點,其他的只是泛泛而談。”

    引號猜測:“因為他們更重要?”

    “可以這么說。”冒號直截了當,“毋庸諱言,在當今的主流語言中,C族語言應用范圍之廣、使用人數之多、影響力之巨都是其他類語言所無法比擬的。它們之間的關系從名字上就能看出:C語言的前身是B語言;其后是C++Java曾被稱為C++++--,意思是在C++上增點東西再減點東西;C##就是四個疊起的加號;最后D語言干脆在字母上進行升級。”

    句號推斷:“B語言、C語言、D語言,下一個該D++D#E語言了。”

    誰知冒號卻說:“E語言已經有了,與Java的語法很像。甚至F語言也有了,但不是C族語言,而是Fortran族的。這不,微軟還在.Net平臺上推出了F#語言,不過這里的F指的是‘Functional’,即函數式。”

    逗號向往著:“不如直接搞個終極的Z語言,成為全世界程序員的唯一指定語言,多省事!”

    “這難度不亞于全人類共用一種語言。”冒號笑道,“愿望是美好的,我們還得面對現實。不扯遠了,你們先談談一下這些C族語言各自的特點吧。”

    眾人心想:老冒怎么跟國足一個毛病,老喜歡回傳,就是不直接射門,真是急煞人也!

    問號揀了個軟柿子:“C語言是C族老大,又是唯一的純過程式語言,當然與眾不同啦。”

    引號一板一眼:“C++在過程式的基礎上又引入對象式和泛型式,同時保持了C的高效性和底層開發能力。”

    逗號接道:“Java既繼承了C++的優點,又克服了C++的復雜性,雖然底層開發能力有所減弱,但具備平臺無關性。”

    句號不緊不慢:“C#兼具C++Java各自的優點,但效率上不如C++,跨平臺方面不如Java。”

    嘆號后悔嘴慢:“剩下一個最陌生的D語言,在第一堂課之前還真沒聽說過,怎么擠上主流語言位置的?我想。。。呃,它總該比C++要高級吧。”

    冒號評價:“各位談得雖然簡單了些,也算八九不離十吧。下面我稍微展開些來講。”

    此時眾人有一個共同的愿望,希望老冒這次能痛快地單刀赴會、直搗黃龍。

    冒號似乎看出大家的心思,開始口若懸河:“關于C語言,前面多次提到。這是一把歷久彌新的寶劍,一旦出鞘,依舊寒光逼人,鋒利無儔。有了它,便如戰將有了佩劍,平添一分獨闖敵營的膽氣。盡管以現代的眼光來看,它存在不少缺點,但即使拋開C語言輝煌的歷史不談,單就其以如此高齡在諸多后輩沖擊之下仍屹立不倒而論,讓人無法對其多加苛求。”

    逗號提出異議:“但語言不是讓人崇拜的,而是讓人運用的。一門語言無論過去如何榮光,如果不適應現代發展趨勢,還是可能被淘汰。”

    “說得非常好!”冒號竟然鼓起掌來,“迄今為止本課堂對于具體知識的講授并不多,但一直提倡獨立思考,不要盲從權威。如果你們能做到這一點,本班的目標也就實現了一半。回頭再說說C語言,它源自Unix操作系統的開發,以其良好的抽象性和可移植性取代了匯編語言作為系統開發語言。因其簡潔實用、靈活高效,很快從系統領域發展到其他領域而成為通用語言。隨著新興語言的崛起以及硬件性能的大幅提高,C語言的缺點也日益顯著:過于寬松的類型檢查、容易出錯的內存管理、相對貧乏的語言特征等等。雖然自身還在發展,它的市場份額日益減少乃不爭的事實。但在相當長的時間內,它在其所擅長的領域里仍會占舉足輕重的一席之地。如果C能借鑒C++命名空間、重載、異常處理和STL等非OO的特征,它的生命力絕不會比任何OOP語言弱。“

    引號咨詢道:“關于C語言的學習,您有何建議?”

    “精讀K&R的《The C Programming Language》,此書不過二百頁,堪稱C語言的劍訣。其中的RDennis Ritchie,是C的創造者,同時也是Unix的締造者之一,是真正的大師。如今的大師,同博士、教授、院士等頭銜一樣,嚴重地通貨膨脹了。”冒號不無感慨。

    問號尖銳地問:“C++既保持了C的底層開發能力,又引入了OOPC的處境想必更加艱難吧?”

    冒號坦承:“這是不假。C++成功的一個重要因素是對C語言的兼容,由此吸引了大批的C程序員。但這不是沒有代價的,C++在兼容C的同時也保留了C的許多缺陷。Java成功的地方有很多,一個不容忽視的因素是它徹底擺脫了與C兼容的桎梏。由于C++C的改革不徹底,又過于龐雜,并且效率上不如C,這使得C仍有其生存空間。略有諷刺意味的是,對C++批判最激烈的往往來自C的社區,比如Linux之父Linus Torvalds就曾激烈地批判過C++。”

    Linus?那可是我的偶像呢!”嘆號驚訝道。

    冒號勸誡:“如果你因為是他的粉絲而后悔學C++,那就是為他人的偏執買單,不管那人名氣有多大。”

    句號指出:“C++最為人詬病的地方有:語法過于復雜,學習曲線陡、開發效率低;支持的范式過多;OOP不徹底;自省(Reflection)功能不足;支持指針操作導致安全隱患;沒有自動垃圾回收,容易內存泄漏;沒有線程支持;沒有豐富的標準庫支持圖形界面、網絡編程等。”

    “罪狀不少哇!這些說法都有一定道理,但也有失公允。且聽我一一道來。”冒號當起了辯護律師,“C++過于復雜這點沒錯,Stroustrup說過一句耐人尋味的話:一種語言不復雜是因為不成熟。成人肯定比兒童復雜,因為他要承擔更大的責任。大家不妨看看Java1.06.0的發展過程,是否應證了這一點?當然C++的復雜度的確高于其他語言,但如果不執著于奇技淫巧,它絕非高不可攀。C++的開發效率相比JavaC#,差距主要在兩個方面:一是標準庫不夠完善,二是需要手工回收垃圾。關于前者,的確是C++的一大軟肋,標準庫竟然連企業應用中最常用的圖形界面、網絡編程、數據庫處理等都不能涵蓋,嚴重障礙了生產力。其實C++也有苦衷,不像JavaC#那樣有大公司的鼎力支持,只靠效率極為低下的標準委員會來維護。98年的一個標準直到03年還在修訂,下一個標準至少要到09年。連Stroustrup都在哭窮,說沒有足夠的人和時間來開發標準庫,可為何廣受贊譽的Boost庫至今仍徘徊在標準門外?考慮到Boost的創辦人大多出自標準委員會,其他無此背景的類庫恐怕更難登C++之堂了。相比之下D語言更慘,雖然天生麗質,苦無豪門青睞,只好一直待字閨中。”

    嘆號感慨:“金錢才是技術的最大推動力啊!”

    “話糙理不糙。”冒號也很無奈,“此外,C++不支持自動垃圾回收,是因為Stroustrup固執地認為這該由library來支持。一方面,C++主張RAIIResource Acquisition Is Initialization)原則,通過析構函數(destructor)或智能指針(smart pointer)能在大多數情況下有效地解決內存釋放問題;另一方面,盡管自動垃圾回收機制逐漸為大眾接受——據說C++0x也將部分地支持它——但這種機制也存在缺陷。比如一個Java程序如果在某一時段極耗內存,由于自動垃圾回收的不定時性,不能保證及時清理內存,可能會拋出OutOfMemoryError。另外,自動垃圾回收機制并不能完全避免內存泄漏問題,Java程序的內存泄漏可能會比C++的更多,因為C++程序員對此更有戒心。”

    問號直奔要害:“您如何看待CC++中的指針?”

    冒號欣然接招:“指針是CC++最大的特色,其他語言要么不支持,要么支持得有限。CC++可以說是成也指針,敗也指針。用得好可以是削鐵如泥的神兵利器,用得不好則可能是自我毀滅的罪惡淵藪。但由于二者定位于系統語言,而指針對于底層操作是必不可少的。同樣道理,二者的數據類型的轉換比其他靜態類型語言更自由,也是源出于此。”

    句號總結:“能力越大,責任越大,風險越大。

    “正是此意!”冒號重重地敲了一下桌子,“此話既適用于編程語言,也適用于程序員。至于C++缺少對自省功能的支持,也是因為追求效率,不愿在元數據上花時間和空間。說到C++支持的范式過多,程序員過于自由,代碼不標準難維護,這就如同埋怨餐館提供的菜式過多以致難以擺出一桌酒席一樣可笑。最后,指責C++不是100OOP的說法更是荒謬之極。OOP又不是金子,含量越高越好。試圖把一切都裝進OOP的箱子里的想法無異于削足適履。典型的如Java中的Math類,邏輯上壓根兒就不存在什么Math對象,清一色的static方法和常量就是最好的諷刺。在C++中只要在mathnamespace中定義一些自由函數就可以了,自然而簡潔。”

    引號發覺:“您好像把對C++所有的責難都化解了。”

    “可恨之人必有可憐之處嘛。”冒號俗語反用,“其實C++仍有不少亟待改進之處,D語言就是很好的啟示。D語言的提供了可控制的垃圾回收器;支持動態數組(dynamic array);支持契約式設計(design by contract);廢除了CC++ 令人頭痛的頭文件(header file)等等。這些都是C++程序員夢寐以求的特征。”

    逗號很奇怪:“為什么D語言名氣這么小?”

    句號吟道:“千里馬常有,伯樂不常有,大腕伯樂更稀有。”

    眾樂。

    冒號結語:“CC++同為系統語言,決定了它們的理念是:優化機器的時間而不是人的時間優化機器的記憶而不是人的記憶;假設編譯器是愚蠢的而程序員是聰明的,因此賦予程序員更多的權利、義務與責任。無視這種背景和理念而去與其他語言相較,必不著筋節。需要強調的是,常見的‘C/C++’的說法很不科學。CC++雖有千絲萬縷的聯系,但一個簡單,一個復雜;一個純過程式,一個集過程式、對象式、泛型式和元編程于一體。貌合神離,不宜混為一談。”

    嘆號一個問題憋了半天,不吐不快:“我有一個問題:如今電腦性能這么高,CC++如此強調運行效率還有必要嗎?”

    “絕對有必要!”冒號斬釘截鐵,“其一、縱向看,用戶的耐心與電腦的速度成反比,早年一個386人們就滿足了,如今卻忍受不了586;其二、橫向比,相對緩慢的系統競爭力也低;其三、在一些領域如人工智能方面,普通電腦的速度還遠遠不能滿足要求,超級計算機的存在就是明證;其四、仍有些程序跑在資源有限的機器上,比如嵌入式系統。”

    引號再次要求:“能推薦一些C++方面的書嗎?”

    冒號直言:“學好C一本書足矣,學好C++即使推薦十本仍有遺珠之憾。可以說C++是苦了編程者,甜了著書人。開個小書單:初級——《C++ Primer》和《Thinking in C++》;中級——《The C++ Programming Language》和《Effective C++》系列;高級——《The C++ In-Depth》系列。這里還要特別推薦一下《The Design and Evolution of C++》,從中你可以看到 C++的設計和演變的來龍去脈,極具啟發性。C++是匹無轡無鞍的野馬,看似桀驁不馴,若能順性而御,必能足踏飛燕,行千里而不勞。”

    posted on 2008-06-05 13:05 鄭暉 閱讀(3168) 評論(27)  編輯  收藏 所屬分類: 冒號和他的學生們

    評論

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-05 15:37 dennis

    c要是向C++靠近,那才是悲劇的開始  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-05 21:29 ron

    感謝。
    回味,繼續聽課。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-05 21:31 ron

    尺有所短寸有所長,選擇一門語言,就是選擇一類應用。贊。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-05 21:44 白色天堂

    每種語言都有自己特點和適用范圍,但c++的問題就是野心太大,想從底層開發到企業級應用都能適合,最后的結果就是個四不像,特性越加越多,語法越來越復雜,但什么都作不好。我不看好c++的前途,Linus的看法是有他的道理的。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-05 22:16 鄭暉

    @白色天堂
    如果你認真看看Linus的原話,你會發現他的狂傲、無知與偏執。他根本不懂c++,甚至不能算是c的專家,連Ritchie都承認c可能被包括c++、Java在內的語言替代。c++的問題與野心無關,c#同樣想從底層開發到企業級應用通吃,關鍵是c++標準委員會推進改革的力度和效率不夠。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言[未登錄] 2008-06-05 23:50 過客

    @鄭暉
    頂你,說得好~~~
    某些人用不好C++就說C++不好,無異于沒錢坐飛機卻對別人說害怕飛機失事才不去坐。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-06 05:50 ELLE

    c#也不比c++簡單,況且c++很注重性能。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-06 09:27 Matthew Chen

    c++的復雜源于多方面的原因,如lz提到了不少,但其實大多數原因正是因為他本身的復雜所引起的,這有點惡性循環,你不夠好用人家就不支持你,所以你就停步不前,越來越不好用。
    oop不一定是萬金油,但是oop就是要作萬金油,一切邏輯上可感知的都可以是對象,從這點上來說,Math是很正常的。
    歷史發展和進化的軌跡是曲折的,退步和埋沒都很正常,不要以為金子總能發光,和氏璧為人所知的時候對原來支持它的主人卻已經沒有任何價值了。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-06 09:55 鄭暉

    @Matthew Chen
    >>>不夠好用人家就不支持你
    微軟以前也支持c++,但一方面不能掌握標準,另一方面要與Sun競爭,搞個J++被Sun告,只好自己搞c#,與c++是否好用并無太多關系。
    >>>一切邏輯上可感知的都可以是對象,從這點上來說,Math是很正常的。
    一切都可以當作對象,但不代表那么做是合適的。
    Math不是對象,只是類,沒有人會new一個Math。對于Math這種永遠不會有非static的方法和域、永遠不必有instance的類,無論從邏輯上還是從語法上看,都應當是命名空間。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-06 13:22 dennis

    @鄭暉
    你對Linus的評價太讓人吃驚了,沒想到。這個系列到現在已經沒啥意義了,一直停留在形而上學的討論,令人乏味。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-06 13:50 鄭暉

    @dennis
    我對Linus的評價是否過分,看看他的的原話就知道了。(參見
    http://advice.cio.com/esther_schindler/linus_torvalds_why_c_sucks)
    他在linux上的成功不代表他就是編程語言上的專家,至少在這方面的造詣遠遠在Ritchie和Stroustrup之下。如果因此得罪了你的偶像而引起你的不快,在此致歉!但我堅持自己的看法。
    此外,形而上學的討論是有意義的,太執著于局部技術的程序員,缺乏對技術的全局感知能力,尤其容易在日新月異的技術面前迷失方向。至于具體的技術細節,本系列稍后將會涉及,還請多提意見!  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-06 13:54 ezcat

    我就是喜歡這個系列討論的形而上學,標新立異,蘊含智慧。提出了很多編程上深層次的思考,揭示了很多自己所不了的東西,實在大開眼界。它本來就不是XX語言學習手冊,教你一板一眼的該怎么寫,怎么用。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-06 15:30 dennis

    @鄭暉
    sorry,我說話都是比較直接的,不好意思。關于linus那番話,國內c++大牛也有很多討論,其中不乏認同的人,我這個不用cpp的人沒資格評價。我只是覺的評價不應該帶太多感性色彩,您恐怕是c++的忠實擁護者,不覺的對linus也談不上c專家的評價太偏激了一點?  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-06 15:35 dennis

    @鄭暉
    形而上學的討論當然是必要的,整體的認知才能對細節有所深入。只是看到現在,我還沒發現開始適當地切入細節,因而比較失望。還是期待您的后續。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-06 15:51 鄭暉

    @dennis
    沒關系。國內關于linus那番話的討論我倒真不清楚,只是個人看法。說linus談不上c專家,或許有些偏激,也可以理解為我的專家標準太高了:-)
    我不是任何語言的忠實擁護者,任何語言都有可愛之處和可恨之處。c++最吸引人的地方是它為程序員提供了最大的發揮的空間,雖然這不是沒有代價的。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-06 21:04 白色天堂

    Linus當初的評論我看過,他只是從os開發人員的角度說了對c++的看法,而且我不覺得有什么很出格的地方。反而你說他連c都不熟悉,不知道到底是誰偏執。

    我說c++應用范圍太廣你拿c#來類比純屬無聊,我還沒聽說有人打算用c#來些os的。

    c++獲得的支持并不少,所有對java有商業支持的大公司幾乎都有研究c++,不存在支持不夠的問題,c++還是這幅鳥樣只能說他的根本就有問題,除非推倒重來。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-06 21:09 白色天堂

    c會被c++和java取代,這種話說出去會笑死人的。c++死18次c都不會死。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言[未登錄] 2008-06-06 22:08 Matthew Chen

    @鄭暉
    當時微軟開發的vc++,標準還沒制定,另外java的崛起也在這個時候,從兩個方面反映了c++都有對商業應用支持不夠的地方:標準化和統一的通用性,“不好用”這個詞很廣泛,很好用,所以我才挑的它。
    命名空間確實是和包還有靜態類都不同的東西,就像是允許函數和類的混合集合吧。也許從你的角度來說是不合適的,但從較純粹的oo的java來說,考慮一下效率和實現難易,卻也只能是“合適”的了。
    你這里好啊,大家都平靜一點討論,不要太吵。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-06 22:47 鄭暉

    @白色天堂
    請仔細閱讀Linus的原話,看看我有沒有冤枉他。僅摘錄一段:“C++ is a horrible language. It's made more horrible by the fact that a lot of substandard programmers use it, to the point where it's much much easier to generate total and utter crap with it. Quite frankly, even if the choice of C were to do nothing but keep the C++ programmers out, that in itself would be a huge reason to use C."(C++ 是一門極其糟糕的語言,因為有大量不合格的程序員在使用,使得它更加糟糕,它非常非常容易產生徹頭徹尾的廢物。非常坦白地說,即使選擇C什么都不做而僅僅是把C++程序員趕出去,這本身就是使用C的一個巨大的理由。)此外還有對boost、STL等偏激的言論,這里不一一說明。

    另外,請不要偷換概念,我并沒有說他不熟悉c,而是說他未必稱得上專家。我眼中的專家,雖不必到Ritchie和Stroustrup之類的大師水平,也當接近,Linus?差得太遠。

    我還沒聽說有人打算用c#來些os的”,你沒聽說不等于沒有,Singularity、SharpOS都是。“純屬無聊”這樣的話有欠禮數。

    “C語言正在被C++,也可能是Java所替代”,這是Ritchie說的,還會笑死人嗎?(google 一下“傳奇的締造者——C語言之父訪談”)
    c++雖然讓人詬病的地方很多,但仍是少數成功的語言之一,這是不容置疑的。說“C++鳥樣",有失風度。

    爭論使人接近真理,爭吵使人遠離真理。   回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-08 03:50 YYX

    @鄭輝
    對于OOP,Bruce Eckel 提出,對于開發設計來說,可以把一個對象看作一個服務提供者,很明顯Math就是這樣一個數學運算的服務提供者  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-08 09:50 鄭暉

    @YYX
    在本系列連載8“并發范式”中我就提出“對象式系統是服務型公司,每個對象是一名服務員”。但請注意,Math是類而非對象,它的使用與一個namespace沒有任何不同。當然,任何函數或函數集合(僅僅包含自由函數的namespace可以認為是函數集合)都可以認為是服務提供者。但引入對象或者OOP最大的目的是:一、賦予對象以狀態、并對此封裝;(Math沒有任何狀態)二、通過繼承來代碼重用(Math沒有狀態,不必產生instance,也就不可能從父類Object那里得到什么好處。)

    至于Java為什么如此設計,本系列下篇將會有所涉及,歡迎討論!  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-11 14:12 藍劍

    上面的好多人都犯了自以為是的錯誤,找理由支持的時候就說好些例子,其實,你們找到的那些例子你自己都不知道是什么,都不理解,就憑一句話來支持你的觀點?
    舉例:
    1:你對Linus的評價太讓人吃驚了,沒想到。--這位讀者是不是真正去理解事情的本源了?
    2:c++獲得的支持并不少,所有對java有商業支持的大公司幾乎都有研究c++。--不知道這位朋友是怎么得出的結論?信口開河是不對的。

    另外,請不要把某一個方面專長的人作為神來看待,正如一個音樂家,可能在其他方面是弱智。一個專家說屁是香的,我們要學會質疑而不是去追捧。
    linus他很好,只是在Linux方面而已,你讓他干別的,他不一定能行。
    現在技術五花八門,能精通一方面就不錯了,想多能很難,全能是不可能的,即使是蓋茨也不行。說實話,Linus比蓋茨差遠了,大家追捧他緊緊是開源而已。

      回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-14 13:28 dennis

    @藍劍
    得了吧,你認為別人自以為是,您又何嘗不是如此?
    -----------------
    另外,請不要把某一個方面專長的人作為神來看待,正如一個音樂家,可能在其他方面是弱智。一個專家說屁是香的,我們要學會質疑而不是去追捧。
    linus他很好,只是在Linux方面而已,你讓他干別的,他不一定能行。
    現在技術五花八門,能精通一方面就不錯了,想多能很難,全能是不可能的,即使是蓋茨也不行。說實話,Linus比蓋茨差遠了,大家追捧他緊緊是開源而已。
    ---------------------------
    這樣的大話、空話,在我看來基本等于放P。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-14 13:29 dennis

    爭論這么多,沒見有人拉出段代碼來評價一番,口頭的大道理誰不會講?至于linus那番話的背景和爭論,不了解的自己看孟巖、劉未鵬、云風等人的blog去。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-15 19:24 鄭暉

    @dennis
    >>>爭論這么多,沒見有人拉出段代碼來評價一番,口頭的大道理誰不會講?
    任何關于語言的紛爭注定是無果而終,即使拋開大道理拿出代碼來講小道理,也是徒費口舌。關于語言,一言蔽之,“沒有糟糕的語言,只有糟糕的程序員”。糟糕的語言根本不會流行,糟糕的程序員卻“流行”得很。

    >>>至于linus那番話的背景和爭論,不了解的自己看孟巖、劉未鵬、云風等人的blog去。
    雖不愿再談此事,但如果真想了解背景,出于實證精神還是應該去看看原文,而不是某某的blog。平心而論,Linus是在別人首先發難的情況下才有此番過激言論的,不可完全當真。只是作為IT名人挑起激烈的語言之爭,顯非明智之舉。君不見C、C++和Java的創始人在一起尚惺惺相惜、相談甚歡,其他人等卻爭得面紅耳赤,是否有些滑稽?

    最后,博客上的交流既是心靈的聚會,也是一種難得的緣分。希望諸位能忘掉彼此之間因一時的情緒之言而造成的不快(說話與編程一樣,哪能一點bug都沒有呢?),冰釋前嫌,保持平和寬容的心境,共同探討,共同進步! 感謝大家的熱情參與!  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-06-15 19:46 dennis

    @鄭暉
    還麻煩您留言了。你誤會我的意思了,我對這個爭論其實一點興趣都沒有,因為肯定爭不出結論:) 看到藍劍同學的一番回復,都是套話空話,忍不住回幾句。你讓linus是去干其他的可能不行,同樣,你讓蓋茨去賣餛飩他也可能不行,這不是典型的廢話?借您寶地,打攪抱歉。  回復  更多評論   

    # re: 冒號和他的學生們(連載18)——系統語言 2008-08-05 17:13 leweslove

    作者寫這篇的時候是否會料到有爭論呢?  回復  更多評論   

    導航

    統計

    公告

    博客搬家:http://blog.zhenghui.org
    《冒號課堂》一書于2009年10月上市,詳情請見
    冒號課堂

    留言簿(17)

    隨筆分類(61)

    隨筆檔案(61)

    文章分類(1)

    文章檔案(1)

    最新隨筆

    積分與排名

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 美女裸免费观看网站| 亚洲乱码卡三乱码新区| 亚洲国产成人久久精品软件| 久草视频免费在线观看| 亚洲视频在线免费播放| 中国人xxxxx69免费视频| 亚洲永久中文字幕在线| 人与禽交免费网站视频| 亚洲国产夜色在线观看| 免费下载成人电影| 亚洲一卡2卡3卡4卡5卡6卡| 国产卡一卡二卡三免费入口| 国产亚洲福利在线视频| 永久黄网站色视频免费直播| 亚洲av无码一区二区三区天堂| 免费一级毛片清高播放| eeuss草民免费| 亚洲Av熟妇高潮30p| 最近中文字幕免费2019| 亚洲av一本岛在线播放| 无码国模国产在线观看免费| 美女视频黄频a免费| 在线亚洲人成电影网站色www| 欧洲人免费视频网站在线| 亚洲精品网站在线观看你懂的| 18国产精品白浆在线观看免费| 在线综合亚洲欧洲综合网站| 狠狠久久永久免费观看| 中文字幕在线观看免费| 久久久久亚洲av无码专区| 在线视频观看免费视频18| 精品在线视频免费| 亚洲av午夜福利精品一区| 精品久久久久久久久免费影院| 青草久久精品亚洲综合专区| 国产国拍亚洲精品福利| 亚洲视频在线观看免费视频| 国产精品亚洲色婷婷99久久精品| 亚洲午夜福利717| 99久久这里只精品国产免费| 黄色a级片免费看|