程序人生-一個程序員對學弟學妹的建議

         在一個論壇上看到的帖子,很長。偷一部分過來,慢慢品味。

 

         ****************************************************************************華麗的分割線****************************************************************************

 

         IT界的技術風潮要不要追趕?

         對一個初學者來說,IT界的技術風潮不可追趕。我時常看見自己的DDMM 們把課本扔了,去買些價格不菲的最新技術的大部頭,這讓我感到非常痛心。而許多搞不清指針是咋回事的BBS站友眉飛色舞的討論C#java裏面可以不用指針等等則讓我覺得好笑。當然我沒有任何歧視某一行業的意識,我只是覺得如果他們把追趕這些時髦技術的時間多花一點在基礎的課程上,那麼他們應該是可以走得更遠的。

        

         計算機技術就等於編程技術?

         有些人即使沒有這個想法,在潛意識中也有這樣的衝動。讓我奇怪的是,許多信息學院的學生也有這樣的念頭。認爲計算機專業就是編程專業,與編程無關的,或者不太相關課程他統統都不管,極端的學生只要書上沒帶編程兩個字他就不看

         編程只是計算機技術應用過程中一種複雜性最低的勞動,這就是爲什麼IT業最底層的人是程序員(CODER)。計算機技術包括了多媒體,計算機網絡,人工智能,模式識別,管理信息系統等等這些方面。編程工作只是在這些具體技術在理論研究或者工程實踐的過程中表達算法的過程。編程的人不一定對計算機技術的瞭解就一定很高。而一個有趣的現象是,不少大師級的計算機技術研究者是不懂編程的。網上的炒作和現實中良好的工作待遇把編程這種勞動神祕化了。其實每一個程序員心裏都明白,自己這些東西,學的時候並不比其它專業難,所以自然也不會高檔到哪裏去。

 

         對概念和語法咬文嚼字有沒有必要?

         我見過一本女生的《計算機網絡原理》教材,這個女生像小學生一樣在書上劃滿了橫槓槓,筆記做得滿滿的,打印出來一定比教材還厚。我不明白的是,像計算機網絡原理這樣的課程有必要做筆記?我們的應試教育的確害了不少學生,在上《原理》這一類課程的時候許多學生像學《馬列原理》一樣逐字背誦記憶。這乃是我見過的最愚蠢的行爲。所謂《原理》,即是需要掌握它爲什麼這樣做,學習why,而不是how(怎樣做)。極端認真的學生背下以太網的網線最大長度,數據幀的長度,每個字段的意義,IP報頭的格式等等,但是忘了路由的原則,忘了TCP/IP協議設計的宗旨。總之許多人花了大量的時間把書背得滾瓜爛熟卻等於什麼也沒學。
        
在學習編程的時候這些學生也是這樣,他們確切的記得C++語法的各個細節。看完了C++ 教程後看《Thinking in C++》(確實是好書),《Inside C++》,《C++ reference》,this C++, that C++……,然後是網上各種各樣的關於C++語法的奇聞逸事,然後發現自己又忘了C++的一些語法,最後回頭繼續惡補。有個師弟就跟我說:“C++ 太難了,學了這裏忘了那裏,學了繼承忘了模板。我的回答道:你不去學就容易了。我並沒有教壞他,只是告訴他,死摳C++的語法就和孔已己炫耀茴香豆的茴字有幾種寫法一樣毫無意義。你根本不需要對的C++語法太關心,動手編程就是了,有不記得的地方一查MSDN就立馬搞定。我有個結論就是,實際的開發過程中對程序語法的瞭解是最微不足道的知識。這是爲什麼我在爲同學用Basic(我以前從沒有學過它)寫一個小程序的時候,只花了半個小時看了看語法,然後再用半個小時完成了程序,而一個小時後我又完全忘記了Basic 的所有關鍵字。

 

         你是不是希望自己的東西能馬上跑起來,變成錢?

         這種想法對一個已經進入職業領域的程序員或者項目經理來說是合理的,而且IT技術進步是如此的快,不跟進就是失業。但是對於初學者來說(尤其是時間充裕的大中專在校生),這種想法是另人費解的。一個並未進入到行業競爭中來的初學者最大的資本便是他有足夠的時間沉下心來學習基礎性的東西,學習why 而不是how。時髦的技術往往容易掌握,而且越來越容易掌握,這是商業利益的驅使,爲了最大化的降低軟件開發的成本。但在IT領域內的現實就是這樣,越容易掌握的東西,學習的人越多,而且淘汰得越快。每一次新的技術出來,都有許多初學者跟進,這些初學者由於缺乏必要的基礎而使得自己在跟進的過程中花費大量的時間,而等他學會了,這種技術也快淘汰了。基礎的課程,比方數據結構,操作系統原理等等雖然不能讓你立馬就實現一個linux(這是許多人嘲笑理論課程無用的原因),但它們能夠顯著的減少你在學習新技術時學習曲線的坡度。而且對於許多關鍵的技術(比方Win32 SDK 程序的設計,DDK的編程)來說甚至是不可或缺的。
        
一個活生生的例子是我和我的一個同學,在大一時我還找不到開機按紐,他已經會寫些簡單的彙編程序了。我把大二的所有時間花在了彙編,計算機體系結構,數據結構,操作系統原理等等這些課程的學習上,而他則開始學習HTMLVB,並追趕ASP的潮流。大三的時候我開始學習Windows 操作系統原理,學習SDK編程,時間是漫長的,這時我才能夠用VC開發出象模象樣的應用程序。我曾一度因爲同學的程序已經能夠運行而自己還在學習如何創建對話框而懊惱不已,但臨到畢業才發現自己的選擇是何等的正確。和我談判的公司開出的薪水是他的兩倍還多。下面有一個不很恰當的比方:假設學習VB編程需要 4個月,學習基礎課程和VC的程序設計需要1年。那麼如果你先學VB,再來學習後者,時間不會減少,還是1年,而反過來,如果先學習後者,再來學VB,也許你只需要1個星期就能學得非常熟練。

 

         你是否真正掌握了基礎課程?

         大學英語-不要覺得好笑。我極力推薦這門課程是因爲沒有專業文檔的閱讀能力是不可想象的。中文的翻譯往往在猴年馬月才會出來,而現在的許多出版社乾脆就直接把E文印刷上去。學習的方法是強迫自己看原版的教材,開始會看不懂,用多了自然熟練。吃得苦下得狠心絕對是任何行業都需要的品質。
        
計算機體系結構和彙編語言-關於體系結構的書遍地都是,而且也大同小異,倒是彙編有一本非常好的書《80x86彙編語言程序設計教程》(清華大學出版社,黑色封面,楊季文著)。你需要着重學習386後保護模式的程序設計。否則你在學習現代操作系統底層的一些東西的時候會覺得是在看天書。
        
計算機操作系統原理-我們的開發總是在特定的操作系統上進行,如果不是,只有一種可能:你在自己實現一個操作系統。無論如何,操作系統原理是必讀的。這就象我們爲一個芯片製作外圍設備時,芯片基本的工作時序是必需瞭解的。這一類書也很多,我沒有發現哪一本書非常出衆。只是覺得在看完了這些書後如果有空就應該看看《Inside Windows 2000(微軟出版社,我看的是E文版的,中文的書名想必是Windows 2000 技術內幕之類吧)。關於學習它的必要性,ZDNET上的另一篇文章已經有過論述。
        
數據結構和算法-這門課程能夠決定一個人程序設計水平的高低,是一門核心課程。我首選的是清華版的(朱戰立,劉天時)。很多人喜歡買C++版的,但我覺得沒有必要。C++的語法讓算法實現過程變得複雜多了,而且許多老師喜歡用模塊這一東西讓算法變得更復雜。倒是在學完了C版的書以後再來瀏覽一下C++的版的書是最好的。
        
軟件工程-這門課程是越到後來就越發現它的重要,雖然剛開始看時就象看馬哲一樣不知所云。我的建議是看《實用軟件工程》(黃色,清華)。不要花太多的時間去記條條框框,看不懂就跳過去。在每次自己完成了一個軟件設計任務(不管是練習還是工作)以後再來回顧回顧,每次都會有收穫。

         當然還有很重要的計算機網絡、面向對象的思想、關係型數據庫、編譯原理。

 

         你是否已經忘記了思考?

         每天讀的書太多,容易讓人迷失方向。一定要在每天晚上想想自己學了些什麼,還有些什麼相關的東西需要掌握,自己對什麼最感興趣,在一本書上花的時間太長還是不夠等等。同時也應該多想想未來最有可能出現的應用,這樣能夠讓你不是追趕技術潮流而是引領技術潮流。同時,努力使用現在已經掌握的技術和理論去製作具有一定新意的東西。堅持這樣做能夠讓你真正成爲一個軟件研發者而不僅僅是一個CODER

 

         你在學習上到底花了多少時間?

         這是對初學者最後的忠告。把每個星期玩CS或者Dota的時間壓縮到最少,不玩它們是最好的。同時,如果你的ASP技術已經能夠來錢,甚至有公司請你兼職的話,這就證明你的天分能夠保證你在努力的學習之後取得更好的收益,你應該去做更復雜的東西。眼光放長遠一些,這無論是對誰都是適用的。 

 

        

 


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