好的程序員做不出好的軟件設計

好的程序員做不出好的軟件設計

你不能看到一個程序員還不錯,就把他推到系統分析師、軟件設計師或軟件架構師的位置上。

如果你在團隊或公司裏尋找一個能勝任軟件架構師或設計師這樣重要位置的人時,首先出現在腦子裏的想法通常是在程序員中選一個最好的。別這麼幹。這樣的位置不是隨意的找個不錯的程序員就能勝任的。把你最資深的程序員晉升到這個位置也未必就合適。

乍一聽你可能感覺荒誕。爲什麼我不能讓一個程序員去做系統設計呢?畢竟,他們是設計程序的,不是嗎?的確是的,沒錯。但你要明白的事情是,設計軟件相對於編寫程序,它需要的是一套完全不同的技能。

讓我們來看看爲什麼一個好的程序員就未必可以做一個好的軟件設計師。但首先,讓我們來問問自己一個問題,是什麼讓一個程序員變的優秀,甚至傑出?要想成爲一個好的程序員,你需要有能力實現真實世界裏重要的軟件。只能夠寫出一個簡單的文本編輯器是遠遠不夠的。

爲了能做到可以解決重大的、複雜的編程問題,一個程序員需要在某個特點的編程語言上進行數年的經驗積累。也就是說,爲了能熟練的使用這種語言、熟悉這種語言的各種特色,他必須專注於這種語言。問題就在這兒。

對於只有錘子的人,他能解決的問題就是釘釘子

如果你專注於一種語言,並能做到精通掌握,那你遇到的問題模式很可能就限制於跟這種語言相關的領域。簡言之,如果你懂PHP,那所有的問題都基本上是跟Web開發相關。相同的道理,如果你全部的知識都集中的Java上,那你對所有問題的解決思路都會沿着面向對象的方向,即使是使用過程式編程對於解決你的問題會更優的情況下,你也會如此。

一個程序員,只懂得一、兩種編程語言,這會嚴重的限制他的解決問題的能力。例如,如果你的編程語言是C語言,對於手頭出現的問題,你絕對不可能想出一種面向對象的解決思路,因爲你的編程語言不提供這樣的語言特徵。跟Haskell程序員不一樣,C++程序員不可能想出函數式解決方案。你的編程語言裏提供了結構體和枚舉類型與否,會嚴重的影響你剖析一個問題的方式。如果你使用的語言的能力很弱,或你只知道少數幾種語言,你解決問題的能力相應的會被削弱。

語言塑造了我們的思維方式

有人說,我們的語言塑造了我們的思考和認知這個世界的方式。我基本上認同這個觀點。當一個人的母語裏的名詞都有性別之分時,他一定不會同說其它種母語的人那樣一提起“警察”這個詞就基本上認爲是男的。當一個人的母語裏對藍色和綠色不區分時,他對世界的感知會和那些有區分的人的感知大不一樣。

如果我們回首中世紀學校的三學科,它們被描述爲:語法解決概念和對象如何在書寫和話語中被表現,用邏輯對它們進行分析,最終以修辭爲目的同他人交流。對於我們來說,編程語言也有語法。如果我們的編程語言不夠強,我們對事物和概念的認識以及對如何表達它們都不會有完整的視野。

語言,我們用來跟人們、跟計算機交流的功能,明顯的影響着我們的思考方式。我們對語言知道的越豐富、越多,越能幫助我們提高解決問題的能力。

那麼,什麼樣的人更合適?

那麼,一個在某一兩種編程語言裏具有專長的程序員,在當他解決一個問題時,會存在一定的侷限。他會侷限於他使用的語言允許他做的事。因此,他不會成爲一個好的軟件設計師或分析師。

如果我們不用這些優秀的程序員,誰又能擔當軟件設計的任務呢?當然不會是那些完全不懂編程的人了。我們需要的是一種通才。一個優秀的軟件設計者必須通曉過程式,面向對象式,函數式,以及邏輯式編程語言—還包括各種優秀的軟件開發方法論。他不能只熟悉一種方法模式、像一個專業領域人員那樣。當然,他自己並不能寫出複雜的程序,因爲他的知識太寬泛。儘管如此,他卻能正確的判斷出怎麼樣的設計纔是一個正確的解決方案。如果問題是處理一個釘子,他會找來一個熟練使用錘子的人;如果問題是處理一個巨石,他會叫來爆破部隊,而不是讓你徒勞的用錘子白費力氣。

[本文英文原文鏈接:Good Programmers Make Bad Designers ]      

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章