• 關于編程學習的七點思索

    1
    程序員 Lua C/C++ Bash Go 20253 次瀏覽

      英文原文:Seven ideas for learning how to program

      原文發布于 2010-11-4

      中國古代思想家孔子(Confucius)功勞中包括對許多事物發表的見解, 從平凡的幸運餅消息(fortune cookie messages)到明顯荒謬的笑話,如“Man who stand on toilet is high on pot.(立于茅廁, 樂于尿壺)”。

      他曾說過一段對人們學習編程有幫助的話:

    • I hear and I forget.(耳聽為虛)
    • I see and I remember.(眼見為實)
    • I do and I understand.(實踐出真知)

      對大多數人來說, 坐在教室里聽課遠非學習編程的理想途徑。 輔以閱讀介紹編程概念的書籍可能會有所助益, 但無法與通過有效閱讀并思考其他人的源代碼直至理解所獲得的實踐技巧相比。

      但是,真的沒有什么方法比喜歡自己動手寫程序更能積累編程技巧。 閱讀一點只能學到一點, 而動手編程則能收獲很多。 找到你想簡化的事情, 并編寫一些程序代碼來通過自動化使它們更容易處理。

      不幸的是,搞清楚什么能做有時會是編程學習中最困難的地方。 基于個人的經驗,答案似乎是你可以一躇而就, 而不是七上八下的事情,并能通過頓悟來找到通過編寫程序來解決問題的方法。

      在尋求這種頓悟時,由于剛開始編程的人知識通常都非常有限,繪制流程圖有助于以你喜歡的方式來事先準備。 請這樣來做, 至少在開始時, 包括搞清楚你每天使用電腦的流程,把其中使用最多的部分簡化繪制出來。 一旦你整理出來,就把在那些情況下特別有用的編程技能作為早期學習的重點。 這樣的機會在一定程度上是稀缺的,你可能要改變計算環境來提供這樣的機會。

      需要做的最重要的事情是要找到一種方法來激勵自己編寫代碼。

      下面是關于如何采取行動學習編程的建議。

      1、數據庫管理系統(DBMSes)

      諸如PostgreSQL, Oracle, Microsoft SQL Server, 以及Informix這種專業、耐用的數據庫管理系統通過存儲過程或存儲函數提供了腳本功能。 最受廣泛認可的語言選項也許是Microsoft SQL Server和Sybase所使用的TransactSQL, 以及Oracle所使用的PL/SQL。 PostgreSQL提供了一個名為PL/pgSQL的類PL/SQL的程序擴展到SQL里,但它也提供了包括PL/Perl、PL/Python、PL /Ruby和 PL/Tcl在內的其他語言的選擇范圍。

      這種編程機會雖然限定于一組特定的問題領域,但如果你是一名DBA(數據庫管理員)或你的工作涉及數據庫開發報告,將會親身體驗到這是非常有用的。

      2、插件

      許多新的電腦游戲提供了編寫和加載插件的功能。 例如, “魔獸世界 (World of Warcraft)”提供了一個使用Lua腳本語言的插件系統。 隨著Firefox聲名鵲起和廣泛使用, 現代網頁瀏覽器往往也提供靈活的插件系統; 在最簡單的情況下,Firefox的插件都是用JavaScript編寫的。 開放源碼的瀏覽器在插件開發方面往往比封閉源代碼的瀏覽器更具吸引力,并且Chromium瀏覽器的插件系統, 很可能成為插件開發者們的第二大目標, 這是因為谷歌Chrome瀏覽器高調的營銷策略以及不設限的許可證 (permissive licensing)政策。

      「PurpleEndurer注:Lua程序設計語言 是一個簡潔、輕量、可擴展的腳本語言。 Lua讀作/’lua/(嚕啊), 是葡萄牙語中”Luna”(月亮)的意思。 詳見:http://zh.wikipedia.org/zh-cn/Lua 」

      其他許多應用程序具有插件和擴展系統,可以提供充分的機會來培養這些迅速發展的編碼技能,甚至包括一些終端仿真器(terminal emulators)和基于控制臺的文本編輯器, 如Vim。 (透露一點好消息:我貢獻了一點代碼到urlpicker項目)

      3、實踐問題

      您可以嘗試解決代碼任務中的通用清單所提供的問題,代碼任務是特別為了給程序員提供實習機會而專業設計的。 歐拉(Project Euler)是一個比較流行的、不論編程語言的項目,包括“一系列具有挑戰性的數學/計算機編程問題”。 歐拉項目收集了上百個問題, 這些問題一般從易到難,足以讓你忙碌很長一段時間。

      「PurpleEndurer注:關于歐拉項目, 可訪問:http://projecteuler.net 」

      其他例子包括RubyQuiz, 它多年來一直在ruby-talk的郵件列表中廣受歡迎。 另外還有CodeKata, 它是Dave Thomas的一個規模較小、壽命較短的項目。 Dave Thomas是《The Pragmatic Programmer(程序員修煉之道)》一書的合著者之一。

      「PurpleEndurer注:關于CodeKata可訪問 http://codekata.pragprog.com/ 」

      這些選項不適合用作自我激勵型探索性學習的任務, 因為它們會讓人撓破頭皮,但如果發現其中的樂趣,它們可以和其它方法一樣用于編程實踐教育。

      4、智能手機(Smartphones)

      應用程序開發行業中最大的新熱潮是智能手機的應用程序。 這種裝置通常需要開發人員使用一種可將裝置的功能發揮到極至的特定語言作為應用平臺,至少要以官方認可的方式進行。

      智能手機開發體系的一個新興產業正在崛起,即允許開發人員用非智能手機平臺原生的其它語言編寫自己的代碼,然后轉化為原生語言的應用程序。 因為不需要學習任何特定的智能手機平臺的官方應用程序開發語言,Web應用程序也沾了光,成為智能手機應用程序開發的一種方法。 選擇語言甚于平臺的另一個方案是使用像諾基亞的N900這樣的設備,它運行Debian發行的Linux系統,可以運行的軟件范圍很寬——包括很多不是為 智能手機設計的軟件。

      側重于多種方法開發智能手機應用程序的書籍和在線教程紛紛出現,特別是Android和iPhone的設備。 一些第三方框架將可以從 HTML + JavaScript 到 Ruby 或 Python 編寫的代碼“編譯”為多種平臺的“本地”應用程序,有時不僅包括智能電話平臺,而且包括桌面系統。 對這種情況也許最令人興奮的是,這些框架和相關的IDE不傾向于試圖解決所有的編程問題,這與同樣出色的編程方式的主要框架,如Visual Studio和.NET框架有所不同。這使得人們有可能通過縮小選項至一個易于管理的問題領域來顯著地簡化開發過程。 其結果是軟件開發風格令初學者感到非常易于接受。

      不足之處是,在學習如何編程時,你可能很難每天都編寫新的智能手機應用程序。 但是,如果您的智能手機的操作系統是類Unix系統(如N900的),同樣的小工具開發項目在工作站和服務器中都非常有用。

      5、電子表格

      如果使用了附帶強大宏系統的電子表格程序,你將擁有一個快速的方法來閱讀其他人(或物)代碼,并編寫自己的代碼。 首先,將你執行次數多、通常需要采取數個繁瑣步驟的任務記錄成一個宏。 接下來,打開宏的源代碼,閱讀并進行編輯,使 之更適合于一般用途。 這是一個非常有限的方法,不會帶來多大的長進,但可能會幫助你上路,自然地喜歡上簡單的腳本代碼。

      使用此類腳本的最常見的電子表格程序可能是微軟Excel。 Excel所使用的VBA是一種貧乏的語言,但是如果你在日常工作中大量使用Excel,這可能是無論如何你都該掌握的一種技能。 OpenOffice.org使用了類似的宏系統,使用方法大致相同,LibreOffice也像微軟Office一樣,提供了學習代碼的機會。

      在任何情況下,編寫程序的門坎都比編寫簡單的命令行shell腳本代碼稍高,因為菜單選項和按鈕需要點擊才能啟用。 入門的成本類似于用市場上的一種主要IDE開始一個新項目,但是一個大幅縮水的“項目”。 這會是一個不錯的主意,可以確保這不僅僅是在日常開發環境中編寫腳本的機會,甚至是加以利用就會很有幫助的。

      6、Unix

      如果你定期使用一些類UNIX系統,在尋找鍛煉初期編程技能的方式時就具有巨大的優勢。 UNIX在簡單腳本自動化方面提供了比任何其他家庭通用操作系統的更多的使用機會,這要感謝平臺上管理腳本的極大靈活性。 在最不復雜的情況 下,一個管理腳本可能只不過是將一系列shell命令保存到一個文件中。 在此基礎上,可以利用簡單的循環和條件結構、輸入輸出處理、文件讀寫、計劃任務來進行擴展。

      通過編寫簡單shell腳本爽過一把后,花一段時間來學習如何用Perl、 Python和Ruby編寫管理腳本對任何一個Unix系統管理員都是值得的。 在Unix環境使用這些語言的關鍵技能包括通過UNIX管道和重定向訪問文本流,處理命令行選項,讀寫文件,使用正則表達式搜索和操作文本。 管理員也想知道編程的公共基礎知識,比如處理輸出、循環(或在某些情況下遞歸),以明確界定的標準為基礎,通過使用條件判斷結構編程來作出決策。

      編寫Unix命令行工具是一塊沃土,有許多機會將腳本語言的巨大能力用于編程。 由于管理腳本開發的靈活性和簡約性要求,編寫工具的范圍可以從一些有用工具的最簡例子到強大的服務器進程,甚至大規模并行任務自動化,負載平衡,啟發式過 濾,和一些其他有趣的問題解決作業,這些問題激起了世界上最好的程序員的興趣。

      雖然幾乎所有通用操作系統都具有一些使用管理腳本的能力,其中相當一部分用途比較窄,另一些操作系統則比較均衡。 Unix在管理腳本的適用條件方面高人一等,因為諸如主要Linux發行版和BSD Unix系統等Unix類系統共享相同的基本運行環境設計,他們都可以從管理腳本和腳本平臺之間的可移植性中受益 —— 只要你按可移植性要求來寫這些腳本 (如通過使用sh或Perl而不是bash, 選擇系統標準sysctl值而不是數據源的proc文件系統)。

      這些工作也適用于非常高級、動態、解釋型語言之外的其它語言。 C, C++, Haskell, Objective-C, Objective Caml, 以及大量其他選項正好合適各類簡單Unix工具的編寫任務。 對于其中的許多語言,即使要完成像小型管理工具的這樣簡單的工程項目,也必須學會更 廣泛的技能,這一要求比Perl, Ruby和Bourne shell的這樣的語言高。 但這些任務與GUI應用程序開發、系統編程、其它經常使用(特別是在其他平臺上的)的任務比起來,其艱巨性對編程初學者來說要小得多。

      實際上,鑒于Unix哲學多年來提供了大量常用工具,這些工具嚴格分工(大部分)并工作良好,類UNIX環境對編程新手的價值中有一部分是充分利用Unix命令行環境力量,鼓勵用戶像程序員那樣去思考,而非觀眾。

      7. Web網頁

      這是一個危險的建議,通過玩JavaScript來學習編程。 這不是因為JavaScript是一種不好的語言,而是因為追求動態用戶體驗的緣故,網頁已經被不加限制地濫用JavaSciprt弄得亂七八糟,因而在 網頁上放縱程序員新手可能會被認為是不負責任的。 在網頁中JavaScript也有一些積極用法,而且可以讓新手們對編寫在瀏覽器中運行的桌面應用程序的想法愈來愈感興趣,這給了我們在程序員職業生涯中 盡早開始學習JavaScript的很多理由。

      事實上,JavaScript是一種最常見的、單獨的客戶端網頁腳本,這也意味著JavaScript可能是最簡單的語言,通過閱讀別人的代碼 就能學習。 找到具有客戶端動態元素的任何網頁,然后右鍵單擊并選擇查看頁面源代碼的選項,你就會發現它布滿了JavaScript的散落片段。 對于更復雜的動態頁面,(X)HTML的網頁甚至可能引用一個純代碼的單獨.js文件。

      在把代碼上傳到公共訪問的Web服務器前要細心檢查,確保它是好的。 如果你想讓更多的有用腳本以本地方式來啟動,瀏覽器擴展性可以讓你將任意腳本應用到你查看的網頁上——而且只適用于你個人的瀏覽體驗。 Firefox的Greasemonkey是一個例子。

      征求有關代碼的反饋

      提高編程技能的另一個偉大方法是,向自己身邊的行家里手征求反饋,并掌握他們分享給你的的知識。 他們可能并不總是彼此認可,但如果你認為他們是值得尊敬的優秀程序員,他們所說的至少可以提示你思考新思想,并以新的方式回顧舊觀念。

      征求反饋的方式很多, 這兒列出幾種:

    • 在開始工作時,選擇具有強大有益社區的程序語言, 如Ruby編程語言有ruby-talk郵件列表,Perl編程語言有PerlMonks網站。 加入這些社區中的一個(或類似其中之一的),并學習該語言的文化和最佳經驗,以及得到最有效幫助的方法。

    • 與另一個程序員結對 。結對編程 (Pair programming)是一種時髦的做法, 已經通過敏捷開發方法的崛起而獲得尊崇。 兩個人走到一起做一個項目,但往往只有其中一個是在任何特定時間實際編寫代碼。 結對程序員輪流編寫代碼,其中一人輸入代碼時,另外一個則在后面閱讀代碼,確保他們都得到大量的編碼時間。 就代碼持續交談可以幫助確保解決給定問題的最好辦法逐漸顯現并最終采用。 任何一個擁有頓悟的人在試圖向另一個人解釋一個問題時,應該認識到結對編程的潛在價值。

    • 尋求導師。找到導師的地方,可以是編程語言社區、朋友或同事之中、開放源碼(Open Source)軟件開發項目、重量級技術主題會議。 學校可能是另一個找到導師的好地方,所謂導師,就是對你、宿舍室友甚至研究小組有好感,,具有不那么傳統而更互敬互讓的輔導制關系的指導老師。 在學習編程過程的初期,與導師一對一的關系有時是獲得反饋的最有價值的方式。 如果你幸運地尋得一位好的導師,你應該好好利用這一資源優勢,并且永遠不要認為這是理所當然的。

    • 在代碼托管網站(如Bitbucket或GitHub)上創建一個項目。 告訴你的程序員朋友,把它張貼到自己的Weblog或Twitter中,并激勵他人閱讀你的代碼,提供反饋意見。 確保問題跟蹤系統是打開的,這樣人們可以通過代碼托管網站的交互功能提交bug或改進建議。

      在實踐技能并獲得達人提供的反饋中,你應該能夠以自己的方式從中學習編程的基礎知識,獲得實際有益的經驗。

      現在開動行動,編寫代碼吧!  原文鏈接

    相似問題

    相關經驗

    相關資訊

    相關文檔

  • sesese色