如果當初學習程式設計時能有人給我這些忠告該多好

jobbole發表於2013-12-06

  Cecily Carver  是多倫多的一位程式媛,和 Jennie Faber 一起創辦了一個遊戲製作工作室。她喜歡歌劇、舞蹈和彈鋼琴。Cecily 在這篇文章分享她在程式設計道路上的所感所想,給出很多值得思考的程式設計箴言以及一些思想誤區,比如在你學習程式設計之前思考一下你的目標、程式設計不是什麼神祕的東西、堅持比方法更重要等,可以讓我們在程式設計路上少走一些彎路,從而有更多的時間學習技術讓自己變的越來越強大。

Cecily Carver

  在你學習程式設計之前思考一下你的目標

  要知道程式設計大多時候就是在創造,當你有最終目標感時道路會更加的清晰。如果你的目標是“學習程式設計”而不是更具體的學習哪種程式及如何讓你的生活更好,那麼你可能會發現這不過是一次令人沮喪的實踐。

  我有點慚愧地承認我學習電腦科學的部分動機是為了證明我聰明,及我想幹“聰明人”的工作。我也喜歡思考數學和理論(《哥德爾、艾舍爾、巴赫:集異璧之大成 》這本書在我易受影響的年紀進入了我的腦海),程式設計是一個不錯的選擇。當然這並不足以使我堅持這麼久,真正讓我堅持的是我發現了程式設計可以將科技與我真正喜愛的東西(如音樂和文學)連線到一起。

  那麼,你想要寫什麼?網站?遊戲?iPhone應用?致富的商業軟體?互動藝術?你是想讓老闆印象深刻?或你是想自動執行一些乏味的任務以讓你有更多的時間看水獺照片嗎(譯者注:這裡應該指有更多的時間看外面的風景)?也許你只是想更具有就業競爭力,因為可以將技術流行詞新增到簡歷,或者只為了實現你的教育需求。所有的這些都是有價值的目標,你得確定知道哪個才是你想要的目標然後相應的去學習吧。

  沒有什麼神祕的東西

  程式設計跟其他東西一樣,是一門技術。跟語言學習一樣,有需要掌握的語法和詞彙;跟數學一樣,有解決特定型別問題的流程方法;像各種工藝和藝術創作一樣,有技術、工具以及人們經年累月發展起來的最佳實踐方案,專門解決各種不同型別的任務,你可以自由的使用、修改或棄之不用。

  Joel Spolsky(一個非常聰明的傢伙,他的一些其他的觀點我也很喜歡且頻繁認同)曾論斷:在有著“程式設計師真正思想”的人和缺乏該領域成功所必備的知識能力的任何人之間有一條很清晰的界限。據他所言,這條界限包括指標和遞迴(這裡這裡有為感興趣的人提供的入門資料)。

  我在學校學習過指標和遞迴,當我掌握了過後,大腦發生了一次愉悅的波動—這種智力快感使我想要將學習電腦科學排在第一位。但是,除了課堂練習外,其他時候用指標和遞迴來完成任務的次數就相對較少了。後來在一次次的幫助他人學習時,我發現大家根本不用掌握這兩項技術中的任何一項就可以完成一些非常有趣有益的專案。

  想知道或怕知道自己是否“足夠聰明”其實沒什麼意義。當然,你的任務越複雜越深奧,你需要掌握的知識水平就越高。不過這也同樣適用於其它的任何領域。除非你計劃完全靠程式設計生活,否則你可能並不需要成為一個掌握遞迴的天才來完成你的任務。

  第一次執行一般不成功,第二次第三次也可能不成功

  當你第一次學習程式設計時,你會很快遇到這樣的特殊經歷:你認為已經按照所想的完成了每一件事,檢查了一遍又一遍,卻發現仍然執行不了(出現bug了)。你完全不知道該從哪開始修復它,錯誤資訊(如果你夠幸運只有一個的話)好像在說“fuck you”。你可能就此放棄,心裡想著自己恐怕永遠也解決不了了,那麼你就不適合幹程式設計這行。我一開始就有這種感覺,嘗試著用C++寫一個程式然後執行它,卻只得到“segmentation fault”這個麻煩。

  但是這種經歷對所有不同技術水平的程式設計師來說都太普遍了,這絕對與你的智商、技術悟性或者是否適合幹程式設計這行沒有任何關係。初學者會碰到這樣的情況,經驗豐富的程式設計師也會碰到這種事情。主要的區別就在於你如何應對這種情況。

  我發現新手程式設計師和有經驗的程式設計師之間一個很大的不同點,就在於一種信念(指有經驗的程式設計師所具有的信念):相信事情出錯是因為邏輯原因並且一定能找出來;相信bug可以修復;相信有辦法實現目標。從“執行錯誤”到“執行正確”的過程可能不是很明顯,但是有耐心你通常都可以找出問題。

  總是有人說你做錯了

  括號應該另起一行括號應該放在同一行用tab鍵來縮排但是tab很邪惡喲;你應該使用儲存過程,但實際上你又不應該用它們;你應該總是對程式碼進行註釋,但是好程式碼不需要註釋

  基本上對於一個特定的問題總是有許多不同的方法,沒有所謂單一的“正確方法”。許多程式設計師都非常擅長倡導他們首選或偏愛的方法,但是那並不意味著這是“唯一正確的方法”。如果與人們面對面爭論後告訴我:我是錯的,那麼我也會盡力搞明白是否他們就一定是正確的,這是我早期職業生涯比較重要的一個方面。

  如果你在一個小組裡與其他人一起程式設計的時候,肯定會有人總是對你做的東西指指點點,有時候他們說的的確是正確的,但是總是值得去探究下看你是否真的“做錯了”。但有時候他們完全就是胡扯或只是再次引起了一場古老而沒有意義的爭論,那麼你最好適應這樣的情況然後忘掉它吧。另一方面,如果你個人喜歡這種古老且沒有意義的爭論的話(比如語法狂,一直看著大家),那麼不用多說,你來對了地方。

  總是有人說你不是一個真正的程式設計師

  HTML不屬於真正的程式設計如果不用vi的話,你就不夠嚴肅認真真正的程式設計師要懂C真正的程式設計師不用Windows有些人從來都學不會你不應該學習程式設計你不是一個計算機程式設計師(但是我是)

  “程式設計”對不同的人有著非常不同的含義,而且現在看起來與過去也不太一樣。有趣的是,大家都知道,工具、包和框架能夠讓初學者甚至受過訓練的開發者更快更容易的做開發,但正因如此這些東西往往被貼上“不是真正的程式設計師”的標籤。(看:“Return of the Real Programmer”)

  其實這背後隱藏的是一種害怕心理:“如果“任何人”敢自稱他們自己是一個真正的程式設計師,那麼這篇文章的題目就沒有意義了(譯者注:也就是都不敢自稱自己是真正的程式設計師)。但是我認為這種保守行為是非常具有破壞性的。

  使用那些讓你最容易開發的工具吧。如果這意味著你的遊戲是用Stencyl 或者GameMaker做的,而不是自己從頭開始寫的,沒關係啊。如果你首次程式設計用的是HTML或者Excel巨集,也OK啊。只要你能堅持下去就行。

  當你越來越舒服的時候(沒任何挑戰力),你會自然的開始找出那些工具受限的不足的(而不是有幫助的)地方接而尋找功能更加強大的工具,但是大部分情況,很少有人會去看你的程式碼或問你用什麼工具—你用這些工具實現了什麼功能才是關鍵。

  憂慮所謂的“極客聲譽(geek cred)”相當於慢性自殺

  如前所述,我過去(尤其在學校)一度非常擔心從我的穿著,我的講話,我選擇的閱讀資料,甚至我的軟體定製選項是不是證明了自己“不是一個真正的極客”(不是真正的極客貌似就沒啥資格進入技術社群),這嚴重消耗了我的精力,後來我決定完全不考慮這些東西后我的技術更強了(譯者注:與其花時間搞那些沒意義的東西不如多學點技術,這樣你的技術就會越來越強)。

  你需要謹記一點:你擅長程式設計的能力與你到底有多適應各種極客亞文化沒有一丁點關係。如果你內心深處知道自己永遠都不會適應這些亞文化(而因此焦慮的話),那就需要加倍的記住了。你為了證明自己所浪費的精力應該用來做真正有有意義的事情,並且就算你是一名無可爭辯的極客,眼窩中流露中可信賴的光芒,那麼也請記住:當你評價其他人的信譽水平時,也並不意味著你認為的就一定對,一定是事實。

  堅持比方法更重要

  我們永遠不缺像學習程式設計的“正確”或“最佳”方法這樣的文章,其實還有很多潛在的方法。你可以從一本書或通過完成互動練習或通過除錯其他人所寫的東西來學習概念。當然,在你第一次學習的時候有許多的語言供你選擇,每種語言都有相應的宣傳和倡導。

  關於“自學程式設計”流程和講習班的一個常見的抱怨就是:一開始你會很愉快的輕鬆度過初級材料的學習,然後會越來越困難,這時你就會很快走上陡峭的學習曲線。你知道如何在頁面上列印輸出一些文字行,但是你不知道從哪開始進行一個“真正的”有用的專案。你可能感覺你只不過遵循了一些指南而沒有真正的掌握,然後你可能就會指責學習資料。

  當你到了這一步後,大部分可用的教程和線上資源都不是那麼有用了,因為他們已經讓你成為一名有經驗的程式設計師了。然後困難進一步加劇為這樣一個事實—“你不清楚自己還有哪些不知道的東西”,而且試圖搞清楚你下一步到底要學習什麼本身就是一個難題。

  不管你遵循的是什麼“程式設計”方案,衝破這堵牆的唯一方法就是持之以恆。這意味著你要持續的嘗試新東西,學習更多的知識,並且一步步的搞明白怎麼去開發你的專案。如果你非常清楚自己為什麼要將程式設計放在首位的話,最後你也非常有可能成功。

  如果你堅持一點一點的鋪磚,可能會花費很長時間才能得到一道牆,但是最終你還是會得到。這時候我先前提到的信念就派上用場了。如果你相信隨著時間和耐心,你可以完成整個程式設計任務,那麼到時候你肯定會達成所願的。

  原文連結: Cecily Carver   翻譯: 伯樂線上 - 敏敏

相關文章