做者: 王路 發佈時間: 2014-03-23 14:00 閱讀: 12493 次 推薦: 64 原文連接 [收藏] 程序員
我零九年看過一本小說,講程序員的故事,今後,瞭解了一個新物種。最近又看《紅樓夢》,史湘雲有條謎語:「溪壑分離,紅塵遊戲,真何趣?名利猶虛,後事終難繼。」我一想,這不就是程序猿嗎? 編程
我學過半年編程,惟一的收穫是記住了一個名字叫譚浩強。讀了那本小說,我知道還有個東西叫「良好的代碼風格」,這幾個字可比譚浩強有意思多了。能夠跨領域應用,比方說,用在寫做上。 多線程
例如,變量的命名。像本文,若是叫《論良好的代碼風格》,姿態就不佳,一個「論」字就讓讀者反胃了。若是叫《如何寫出良好風格的代碼》,太裝了,好像本身是編程大師似的。換一種叫法,《扯扯良好代碼風格的淡》,就比如南鑼鼓巷走了一圈,感受親民多了。 函數
不過,本文也沒那麼叫,由於做者不忍心欺負程序猿。程序猿是很實誠的物種,被題目忽悠進來,發現做者根本不懂編程,就會憤怒得跟猩猩似的。可也不是不講編程的書就對程序猿無用,《禪與摩托車維修藝術》就很好,適合程序員讀。 線程
閒話休提。說到變量命名,金庸就是個中高手。像四大惡人的外號:惡貫滿盈,作惡多端,凶神惡煞,窮兇極惡——同類型變量中包含特定的元素,一看就記住了。再比方,穆念慈和包惜弱,這兩人從未謀面,名字倒是工穩的對仗,暗指二人是母女關係:穆念慈的「慈」,就是一個指針指向包惜弱,包惜弱的「弱」也是一個指針指向穆念慈。慈就是母,弱就是子嘛。 3d
《俠客行》開頭有個「賣餅老者」,賣餅老者有沒有名字呢?有,叫吳道通。那金庸爲何不直接稱呼他「吳道通」呢?答曰:佔用內存。讀者記太多名字會累的,哪怕名字都是丁不3、包不一樣這種,多了也記不住。一個無名小卒,戲份太少,特意安個名字不划算。名字至關於一個指針,讀者看到名字,首先想到這我的的特徵和身份,才明確這我的。對於戲份太少的角色來說,變量不存在屢次賦值的問題,安排指針是大大的浪費。 指針
但金庸仍是說出了他的名字,不過金庸並非直接以敘述的方式告訴讀者他叫吳道通,而是經過他的對手罵他:「姓吳的,你想怎樣……吳道通,你到底要怎樣……」接下來,就把他名字天然替換成吳道通了。爲何又要替換呢?由於緊接着出現了第二個「老者」,若不替換,這老者和那老者就犯了重名的問題。可見,「老者」其實至關於一個局部變量。一樣,「胖子」、「店小二」也是。 blog
《俠客行》第一章是這麼寫的: 遊戲
汴梁城外的一個小鎮,暮色時分,四圍響起了馬蹄聲,由遠而近,浩浩蕩蕩,沒人知道出了什麼事情。——這時,金庸把筆鋒宕開,寫鎮上人的各類驚慌失措,戰戰兢兢,因而小鎮氣氛更加凝重緊張。緊接着,馬蹄涌入城內,一幫兇神惡煞的人列隊排開,當中一人穿着皮靴踏着石板路走來…… 整個暮光下的小鎮上,惟一的聲音是他的皮靴聲。惟獨有個賣餅老漢,依舊作燒餅,對一切置若罔聞。此人不忿上前,賣餅老漢順手把他滅了。但是,一個冷眼旁觀的老者周牧又站出來,把賣餅老漢解決了。而周牧見了安金刀,卻遠不是安金刀對手。這時,石清閔柔出現了,果斷把安金刀打趴下了…… 而後,謝煙客閃亮登場,前邊的全部人物,一律變成了小嘍囉……內存
以上,就是一段很好的代碼。好在哪裏?好在語句間的關係清晰明瞭,好在各變量和函數定義得一絲不苟。全部的語句之間,層次條理極爲鮮明。一個語句是一個語句,一個函數是一個函數。不粘連,不糾結。每段代碼要解決什麼問題,別人一看就知。不是全部代碼混成一鍋粥。各小段代碼單獨拎出來,各各是獨立的,各各都好看;但在整體上,又能造成一股協力,指向問題最終的解決。
文章也該這麼寫。輪到每一個配角的戲份時,要當成主角去寫,同時,全部的戲份從總體上看,又要層層遞進。文章各段落之間也要造成一股協力,每一個小段落既能單獨拎出來成立,還要成爲整篇文章的一塊磚,不能率爾刪去。若前者作不到,文章就太粗糙不夠細膩,若後者作不到,文章就淪落成了段子集。
在處理複雜的問題時,每每沒法一上手就針對問題自己來提出解決方案,而要先創建起一些基本的模型,再將模型的約束條件漸次放鬆,獲得更爲廣泛的通常的模型,再將多個這樣的模型組合在一塊兒,使之複雜化。
好的文章也如此,它必定不是單線程的,必然是多線程的。所謂多線程並非指存在多個主題,它仍然是一個主題和中心,但它蘊藏着多種內涵和意義,全部內涵又必須是統一在大主題之下的。
像《天龍八部》這部大做品,就極具複雜性。由於過於複雜,整個前15回都是在界定關係,創建模型:段譽上來遇見的無量劍派的鬥爭,是三十回之後的逍遙派的伏線;鳩摩智到大理取六脈神劍劍譜也直接指向四十回後帶頭大哥和報信人的問題。北喬峯、南慕容、大理段氏、江南王氏、吐蕃、丐幫,西夏一品堂、逍遙派,除了少林以外,幾乎全部重要的函數和模型,都在前15章定義清晰了。
但變量並無全數出現。由於有些變量必須到問題複雜到必定程度才能定義。主要人物中,蕭峯到了第14回纔出場,虛竹到了29回纔出場,蕭峯出場前已經有了30萬字,虛竹出場前已經有了60萬字。直到40回後,少林寺大會纔將整部小說推向大高潮。少林寺那段之因此是大高潮,是由於在那個模型裏,幾乎全部的變量、函數、模型都包含進來了,而沒有一個是以前未精肯定義過的。
可見,金庸筆下的複雜場面是龍鬚麪,雖細,但一根是一根,根根拎得清。換我的寫,就糉成一坨了。
以上,是良好的代碼風格在寫做上應用的一些簡單探討。
但須要說明的是,並不是全部的好文章代碼風格都好。也有一些大牛做者,代碼故意晦澀,卻被尊爲圭臬。像周做人的散文,陳散原的詩就是。——老子就是不友好,愛咋咋地。別人寫代碼,儘可能把句子拆短,他卻三五行代碼硬是擰成一行。他要的就是這個效果。他的着眼點不是複雜問題的清晰解決,而是解決思路的別緻性。這是另外一種風格,本文就不細表了。