經驗分享(一)一位高階程式設計師給學弟學妹的建議

2021-05-26 09:48:05 字數 4414 閱讀 1067

我始終認為,對乙個初學者來說,it 界的技術風潮是不可以追趕的,而且也沒有能力去追趕。我時常看見自己的ddmm 們把課本扔了,去賣些**不菲的諸如c#, vb.net 這樣的大部頭,這讓我感到非常痛心。而許多搞不清指標是咋回事的bbs 站友眉飛色舞的討論c# 裡面可以不用指標等等則讓我覺得好笑。c# 就象當年的asp 一

樣,「忽如一夜春風來,千樹萬樹梨花開」,結果許多學校的資訊學院成了「web 學院」96,97 級的不少大學生都去做web 了。當然我沒有任何歧視某一行業的意識。我只是覺得如果他們把追趕這些時髦技術的時間多花一點在基礎的課程上應該是可以走得更遠的.

幾個誤區

初學者對c# 風潮的追趕其實也只是學習過程中經常遇到的幾個誤區之一。我將用一些實際的例子來說明這些現象,你可以按部就班的看看自己是不是屬於其中的一種或者幾種:

1.認為計算機技術等於程式設計技術:

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

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

2.咬文嚼字的孔已己作風:

我見過一本女生的《計算機網路原理》教材,這個女生像封學生一樣在書上劃滿了橫槓槓,筆記做得滿滿的,列印出來一定比教材還厚。我不明白的是,像計算機網路原理 這樣的課程有必要做筆記?我們的應試教育的確害了不少學生,在上《原理》這一類課程的時候許多學生像學《馬列原理》一樣逐字背誦記憶。這乃是我見過的最愚蠢的行 為。所謂《原理》,即是需要掌握它為什麼這樣做,學習why ,而不是how (怎樣做)。極端認真的學生背下乙太網的網線最大長度,資料幀的長度,每個欄位的意義 ,ip 報頭的格式等等,但是忘了路由的原則,忘了tcp/ip 協議設計的宗旨。總之許多人花了大量的時間把書背得滾瓜爛熟卻等於什麼也沒學。

在學習程式設計的時候這些學生也是這樣,他們確切的記得c++ 語法的各個細節。看完了c++ 教程後看《thinkingin c++ 》(確實是好書),《inside c++ 》,《c++ reference 》,this c++, that c++ ……,然後是網上各種各樣的關於c++ 語法的奇聞逸事,然後發現自己又忘了c++ 的一些語法,最後回頭繼續惡補…。有個師弟就跟我說:「c++ 太難了,學了這裡忘了那裡,學了繼承忘了模板。」 我的回答道:「你不去學就容易了」。我並沒有教壞他,只是告訴他,死摳c++ 的語法就和孔已己炫耀茴香豆的茴字有幾種寫法一樣毫無意義。你根本不需要對的c++ 語法太關心,動手程式設計就是了,有不記得的地方一查msdn 就立馬搞定。我有個結論就是,實際的開發過程中對程式語法的了解是最微不足道的瞄識。這是為什麼我在為 同學用basic (我以前從沒有學過它)寫乙個封程式的時候,只花了半個封時看了看語法,然後再用半個封時完成了程式,而乙個封時後我又完全忘記了basic 的所有關鍵字。

3. 不顧基礎,盲目追趕時髦技術:

終於點到題目上來了。大多數的人都希望自己的東西能夠馬上跑起來,變成錢。這種想法對乙個已經進入職業領域的程式設計師或者專案經理來說是合理的,而且it 技術進步 是如此的快,不跟進就是失業。但是對於初學者來說(尤其是時間充裕的大中專在校生),這種想法是另人費解的。乙個並未進入到行業競爭中來的初學者最大的資本便是 他有足夠的時間沉下心來學習基礎性的東西,學習why 而不是how 。時髦的技術往往容易掌握,而且越來越容易掌握,這是商業利益的驅使,為了最大化的降低軟體開發的成本。但在it 領域內的現實就是這樣,越容易掌握的東西,學習的人越多 ,而且淘汰得越快。每一次新的技術出來,都有許多初學者跟進,這些初學者由於缺乏必要的基礎而使得自己在跟進的過程中花費大量的時間,而等他學會了,這種技術也 快淘汰了。基礎的課程,比方資料結構,作業系統原理等等雖然不能讓你立馬就實現乙個linux (這是許多人嘲笑理論課程無用的原因),但它們能夠顯著的減少你在 學習新技術時學習曲線的坡度。而且對於許多關鍵的技術(比方win32 sdk 程式的設計,ddk 的程式設計)來說甚至是不可或缺的。

乙個活生生的例子

我和我的乙個同學,在大一時我還找不到開機按紐,他已經會寫些簡單的匯程式設計序了。我把大二的所有時間花在了彙編,計算機體系結構,資料結構, 作業系統原理等等這些課程的學習上,而他則開始學習html 和vb ,並追趕asp 的潮流。大三的時候我開始學習windows 作業系統原理,學習sdk 程式設計,時間是漫長的,這時我才

能夠用vc 開發出象模象樣的應用程式。我曾一度因為同學的程式已經能夠執行而自己還在學習如何建立對話方塊而懊惱不已,但臨到畢業才發現自己的選擇是何等的正確。和我談判的公司開出的 薪水是他的兩倍還多。下面有乙個不很恰當的比方:假設學習vb 程式設計需要4 個月,學習基礎課程和vc 的程式設計需要1 年。那麼如果你先學 vb

,再來學習後者,時間不會減少,還是1 年,而反過來,如果先學習後者,再來學vb ,也許你只需要1 個 是期就能學得非常熟練。

幾個重要的基礎課程

大學英語-不要覺得好笑。我極力推薦這門課程是因為沒有專業文件的閱讀能力是不可想象的。中文的翻譯往往在猴年馬月才會出來,而現在的許多出版社乾脆就直接把e 文印刷上去。學習的方法是強迫自己看原版的教材,開始會看不懂,用多了自然熟練。吃得苦下得狠心絕對是任何行業都需要的品質。

計算機體系結構和組合語言-關於體系結構的書遍地都是,而且也大同封異,倒是彙編有一本非常好的書《80x86 組合語言程式設計教程》(清華大學出版社,黑色封 面,楊季文著)。你需要著重學習386 後保護模式的程式設計。否則你在學習現代作業系統底層的一些東西的時候會覺得是在看天書。

計算機作業系統原理-我們的開發總是在特定的作業系統上進行,如果不是,只有一種可能:你在自己實現乙個作業系統。無論如何,作業系統原理是必讀的。這就象我們 為乙個晶元製作外圍裝置時,晶元基本的工作時序是必需了解的。這一類書也很多,我沒有發現哪一本書非常出眾。只是覺得在看完了這些書後如果有空就應該看看《in side windows 2000 》( 微軟出版社,我看的是e 文版的,中文的書名想必是windows 2000 技術內幕之類吧) 。關於學習它的必要性,zdnet 上的另一篇文章已經有過論述。

資料結構和演算法-這門課程能夠決定乙個人程式設計水平的高低,是一門核心課程。我首選的是清華版的(朱戰立,劉天時)。很多人喜歡買c++ 版的,但我覺得沒有必 要。c++ 的語法讓演算法實現過程變得複雜多了,而且許多老師喜歡用模組這一東西讓演算法變得更複雜。倒是在學完了c 版的書以後再來瀏覽一下c++ 的版的書是最好的 。

軟體工程-這門課程是越到後來就越發現它的重要,雖然剛開始看時就象看馬哲一樣不瞄所云。我的建議是看《實用軟體工程》(黃色,清華)。不要花太多的時間去記條 條框框,看不懂就跳過去。在每次自己完成了乙個軟體設計任務(不管是練習還是工作)以後再來回顧回顧,每次都會有收穫。

windows

程式設計-《北京大學出版社,petzold 著》我建議任何企圖設計windows 程式的人在學習vc 以前仔細的學完它。而且前面的那本《inside windows 2000 》也最好放到這本書的後面讀。在這本書中,沒有c++ ,沒有gui ,沒有控制項。有的就是如何用原始的c 語言來完成windows 程式設計。在學完了它以後,你才會發現vc 其實是很容易學的。千萬不要在沒有看完這本書以前提前學習vc ,你最好碰都不要碰。我瞄道的許多名校甚至都已經用它作 為教材進行授課。可見其重要。

上面的幾門課程我認為是必學的重要課程(如果你想做windows 程式設計師)。

對於其它的課程有這樣簡單的選擇方法:如果你是計算機系的,請學好你所有的專業基礎課。如果不是,請參照計算機系的課程表。如果你發現自己看一本書時無法看下去了,請翻到書的最後,看看它的參考文獻,找到它們並學習它們,再回頭看這本書。如果一本書的書名中帶有「原理」兩個字,你一定不要去記憶它其中的細節,你應該以一天至少50 頁的速度掌握其要領。盡可能多的在計算機上實踐一種理論或者演算法。

你還可以在csdn 上閱讀到許多書評。這些書評能夠幫助你決定讀什麼樣的書。

日三省乎己

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

把最多的時間花在學習上

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

相信你已經能夠決定是否學習c #或者什麼時候去學它了。

一位程式設計師的忠告

諸位,咱當網路工程師也是幾年了,不算有出息,環顧四周,也沒有看見幾個有出息的!回顧工程師生涯,感慨萬千,願意講幾句掏心窩子的話,也算給咱們師弟師妹們提個醒,希望他們比咱們強!1 好好規劃自己的路,不要跟著感覺走!根據個人的理想決策安排,絕大部分人並不指望成為什麼院士或教授,而是希望活得滋潤一些,爽一...

一位程式設計師的忠告

1 好好規劃自己的路,不要跟著感覺走!根據個人的理想決策安排,絕大部分人並不指望成為什麼院士或教授,而是希望活得滋潤一些,爽一些。那麼,就需要慎重安排自己的軌跡。從哪個行業入手,逐漸對該行業深入了解,不要頻繁跳槽,特別是不要為了一點工資而轉移陣地,從長遠看,這點錢根本不算什麼,當你對乙個行業有那麼幾...

一位程式設計師的忠告

1 好好規劃自己的路,不要跟著感覺走!根據個人的理想決策安排,絕大部分人並不指望成為什麼院士或教授,而是希望活得滋潤一些,爽一些。那麼,就需要慎重安排自己的軌跡。從哪個行業入手,逐漸對該行業深入了解,不要頻繁跳槽,特別是不要為了一點工資而轉移陣地,從長遠看,這點錢根本不算什麼,當你對乙個行業有那麼幾...