轉(zhuǎn)載自什么才算是真正的編程能力匙铡?
作者:IT程序獅
知乎上看到一題主的發(fā)問:
還在讀書图甜,也在實(shí)驗(yàn)室?guī)兔ψ隽诵〇|西,自己也搭過幾個(gè)網(wǎng)站鳖眼。在周圍人看來似乎好像我很厲害黑毅,做了那么多東西,但是我發(fā)現(xiàn)這些東西雖然是我做的钦讳,但是實(shí)際上我手把手自己寫的代碼卻并沒有多少矿瘦,很多都是用開源的東西,我寫的代碼無非是把別人的東西整合下愿卒,類似于膠水一樣的工作缚去。 我之前所認(rèn)為的編程是全手動(dòng)一行一行敲代碼,但是現(xiàn)在我發(fā)現(xiàn)哪怕是工程上也有很多人是復(fù)制黏貼來解決問題的琼开,并且提倡不要重復(fù)造輪子易结。 但是靠谷歌和復(fù)制別人的輪子,雖然我做出了很多東西柜候,可是我并不覺得自己能力上有提升搞动,倒是利用搜索引擎的能力的確提升了不少。而學(xué)校里另外一波搞ACM的人渣刷,他們每天刷題練算法鹦肿,或許倒是的確提升了點(diǎn)編程能力,但是對(duì)工程幾乎一竅不通辅柴。 所以我現(xiàn)在就很困惑箩溃,所謂的編程能力到底是什么,我該如何提升自己的編程能力碌嘀?
在眾多回答者中碾篡,劉賀的回答得到了眾多網(wǎng)友的肯定。他通過計(jì)算機(jī)科學(xué)的理論和系統(tǒng)知識(shí)開始闡述觀點(diǎn)筏餐,并提出了提高系統(tǒng)編程能力的一些方法和建議开泽。或許以下的回答魁瞪,你能找到一些啟發(fā)穆律。
非常好的一個(gè)問題。這可能是我在知乎見到過的問編程有關(guān)的問題中問得最好的一個(gè)了导俘。我非常喜歡這個(gè)問題峦耘。
計(jì)算機(jī)科學(xué)有兩類根本問題。一類是理論:算法旅薄,數(shù)據(jù)結(jié)構(gòu)辅髓,復(fù)雜度泣崩,機(jī)器學(xué)習(xí),模式識(shí)別洛口,等等等矫付。一類是系統(tǒng):操作系統(tǒng),網(wǎng)絡(luò)系統(tǒng)第焰,分布式系統(tǒng)买优,存儲(chǔ)系統(tǒng),游戲引擎挺举,等等等等杀赢。
理論走的是深度,是在追問在給定的計(jì)算能力約束下如何把一個(gè)問題解決得更快更好湘纵。而系統(tǒng)走的是廣度脂崔,是在追問對(duì)于一個(gè)現(xiàn)實(shí)的需求如何在眾多的技術(shù)中設(shè)計(jì)出最多快好省的技術(shù)組合。
搞ACM的人梧喷,只練第一類脱篙。像你這樣的更偏向于第二類。其實(shí)挺難得的伤柄,但很可惜的是第二類能力沒有簡(jiǎn)單高效的測(cè)量考察方法,不像算法和數(shù)據(jù)結(jié)構(gòu)有ACM競(jìng)賽文搂,所以很多系統(tǒng)的苗子都因?yàn)槿鄙偌?lì)和正確引導(dǎo)慢慢就消隱了适刀。
所以比爾蓋茨才會(huì)說,**看到現(xiàn)在學(xué)編程的人經(jīng)常都把編程看作解各種腦筋急轉(zhuǎn)彎的問題煤蹭,他覺得很遺憾笔喉。 **
做系統(tǒng),確實(shí)不提倡“重復(fù)發(fā)明輪子”硝皂。但注意常挚,是不提倡“重復(fù)發(fā)明”,不是不提倡“重新制造”稽物。恰恰相反的奄毡,我以為,系統(tǒng)的編程能力正體現(xiàn)在“重新制造”的能力贝或。
能把已有的部件接起來吼过,這很好。但當(dāng)你恰好缺一種關(guān)鍵的膠水的時(shí)候咪奖,你能寫出來嗎盗忱?當(dāng)一個(gè)已有的部件不完全符合你的需求的時(shí)候,你能改進(jìn)它嗎羊赵?如果你用的部件中有bug趟佃,你能把它修好嗎?在網(wǎng)上繁多的類似功能的部件中,誰好誰壞闲昭?為什么罐寨?差別本質(zhì)嗎?一個(gè)開源代碼庫(kù)汤纸,你能把它從一個(gè)語言翻譯到另一個(gè)語言嗎衩茸?從一個(gè)平臺(tái)移植到另一個(gè)平臺(tái)嗎?能準(zhǔn)確估計(jì)自己翻譯和移植的過程需要多少時(shí)間嗎贮泞?能準(zhǔn)確估計(jì)翻譯和移植之后性能是會(huì)有提升還是會(huì)有所下降嗎楞慈?
系統(tǒng)編程能力體現(xiàn)在把已有的代碼拿來并變成更好的代碼,體現(xiàn)在把沒用的代碼拿來并變成有用的代碼啃擦,體現(xiàn)在把一個(gè)做好的輪子拿來能畫出來輪子的設(shè)計(jì)藍(lán)圖囊蓝,并用道理解釋出設(shè)計(jì)藍(lán)圖中哪些地方是關(guān)鍵的,哪些地方是次要的令蛉,哪些地方是不容觸碰的聚霜,哪些地方是還可以改進(jìn)的。
如果你一點(diǎn)不懂理論珠叔,還是應(yīng)該學(xué)點(diǎn)的蝎宇。對(duì)于系統(tǒng)性能的設(shè)計(jì)上,算法和數(shù)據(jù)結(jié)構(gòu)就像在自己手頭的錢一樣祷安,它們不是萬能的姥芥,但不懂是萬萬不行的。
怎么提高系統(tǒng)編程能力呢汇鞭?土辦法:多造輪子凉唐。就像學(xué)畫畫要畫雞蛋一樣,不是這世界上沒有人會(huì)畫雞蛋霍骄,但畫雞蛋能馴服手指台囱,感受陰影線條和筆觸。所以读整,自己多寫點(diǎn)東西吧簿训。寫個(gè)編譯器?渲染器米间?操作系統(tǒng)煎楣?web服務(wù)器?web瀏覽器车伞?部件都一個(gè)個(gè)換成自己手寫的择懂,然后和已有的現(xiàn)成部件比一比,看看誰的性能好另玖,誰的易用性好困曙?好在哪兒表伦?差在哪兒?為什么慷丽?
更聰明一點(diǎn)的辦法:多拆輪子蹦哼。多研究別人的代碼是怎么寫的。然而這個(gè)實(shí)踐起來經(jīng)常很難要糊。原因:大部分工業(yè)上用的輪子可能設(shè)計(jì)上的思想和技術(shù)是好的纲熏,都設(shè)計(jì)和制造過程都很爛,里面亂成一團(tuán)锄俄,讓人乍一看毫無頭緒局劲,導(dǎo)致其對(duì)新手來說非常難拆。這種狀況其實(shí)非常糟糕奶赠。所以鱼填,此辦法一般只對(duì)比較簡(jiǎn)單的輪子好使,對(duì)于復(fù)雜的輪子毅戈,請(qǐng)量力而行苹丸。
輪子不好拆,其實(shí)是一個(gè)非常嚴(yán)重的問題苇经。重復(fù)發(fā)明輪子固然是時(shí)間的浪費(fèi)赘理,但當(dāng)輪子復(fù)雜而又不好拆的時(shí)候,尤其是原來造輪子的人已經(jīng)不在場(chǎng)的時(shí)候扇单,重新發(fā)明和建造輪子往往會(huì)成為無奈之下最好的選擇商模。這是為什么工業(yè)界在明知道重復(fù)發(fā)明/制造輪子非常不好的情況下還在不斷重復(fù)發(fā)明/制造輪子的根本原因。
程序本質(zhì)是邏輯演繹的形式化表達(dá)令花,記載的是人類對(duì)這個(gè)世界的數(shù)字化理解。不能拆的輪子就像那一篇篇丟了曲譜的宋詞一樣凉倚,能讀兼都,卻不能唱。
鄙人不才稽寒,正在自己研究怎么設(shè)計(jì)建造一種既好用又好拆的輪子扮碧。您沒那么幸運(yùn),恐怕是等不到鄙人的技術(shù)做出來并發(fā)揚(yáng)光大了杏糙。在那之前慎王,多造輪子,多拆好拆的小輪子宏侍,應(yīng)該是提高編程能力最好的辦法了赖淤。
以上。嗯谅河。