電腦科學與技術學習心得

來源:互聯網
上載者:User

[轉]電腦科學與技術學習心得

ftom: zhy920.bokee.com/1438004.html                         

電腦科學與技術反思錄
電腦科學與技術這一門科學深深的吸引著我們這些同學們,上電腦系已經有近
三年了,自己也做了一些思考,我一直認為電腦科學與技術這門專業,在本科階段是不
可能切分成電腦科學和電腦技術的,因為電腦科學需要相當多的實踐,而實踐需
要技術;每一個人(包括非電腦專業),掌握簡單的電腦技術都很容易(包括程式設
計),但電腦專業的優勢就在於,我們掌握許多其他專業並不“深究”的東西,例
如,演算法,體繫結構,等等。非電腦專業的人可以很容易地做一個晶片,寫一段程
序,但他們做不出電腦專業能夠做出來的大型系統。今天我想專門談一談電腦科
學,並將重點放在計算理論上。

電腦理論的一個核心問題——從數學談起:
記得當年大一入學,每周六課時高等數學,天天作業不斷(那時是六日工作制)。頗
有些同學驚呼走錯了門:咱們這到底念的是什麼系?不錯,你沒走錯門,這就是電腦科
學與技術系。我國電腦科學系裡的傳統是培養做學術研究,尤其是理論研究的人(方
向不見得有問題,但是做得不是那麼盡如人意)。而電腦的理論研究,說到底了,如
網路安全,圖形映像學,視頻音頻處理,哪個方向都與數學有著很大的關係,雖然也許
是正統數學家眼裡非主流的數學。這裡我還想闡明我的一個觀點:我們都知道,數學是
從實際生活當中抽象出來的理論,人們之所以要將實際抽象成理論,目的就在於想用抽
象出來的理論去更好的指導實踐,有些數學研究工作者喜歡用一些現存的理論知識去推
導若干條推論,殊不知其一:問題考慮不全很可能是個錯誤的推論,其二:他的推論在
現實生活中找不到原型,不能指導實踐。嚴格的說,我並不是一個理想主義者,政治課
上學的理論聯絡實際一直是指導我學習科學文化知識的航標(至少我認為搞電腦科學
與技術的應當本著這個方向)。

其實我們電腦系學數學光學高等數學是不夠的(典型的工科院校一般都開的
是高等數學),我們應該像數學系一樣學一下數學分析(清華電腦系開的好像就是數
學分析),數學分析這門科學,咱們學電腦的人對它有很複雜的感情。在於它是偏向
於證明型的數學課程,這對我們培養良好的分析能力極有協助。我的軟體工程學導師北
工大數理學院的王儀華先生就曾經教導過我們,數學系的學生到軟體企業中大多作軟體
設計與分析工作,而電腦系的學生做程式員的居多,原因就在於數學系的學生分析推
理能力,從所受訓練的角度上要遠遠在我們之上。當年出現的怪現象是:電腦系學生
的高中數學基礎在全校數一數二(希望沒有冒犯其它系的同學),教學課時數也僅次於數
學系,但學完之後的效果卻不盡如人意。難道都是學生不努力嗎,我看未見得,方向錯
了也說不一定,其中原因何在,發人深思。

我個人的淺見是:電腦系的學生,對數學的要求固然跟數學系不同,跟物理類差別則
更大。通常非數學專業的所謂“高等數學”,無非是把數學分析中較困難的理論部分刪
去,強調套用公式計算而已。而對電腦系來說,數學分析裡用處最大的恰恰是被刪去
的理論部分。說得難聽一點,對電腦系學生而言,追求算來算去的所謂“工程數學”
已經徹底地走進了誤區。記上一堆曲面積分的公式,難道就能算懂了數學?那倒不如現
用現查,何必費事記呢?再不然直接用Mathematics或是Matalab好了。
我在系裡最愛做的事情就是給學弟學妹們推薦參考書。中文的數學分析書,一般都
認為以北大張築生老師的“數學分析新講”為最好。萬一你的數學實在太好,那就去看
菲赫金哥爾茨的“微積分學教程”好了--但我認為沒什麼必要,畢竟你不想轉到數學系
去。吉米多維奇的“數學分析習題集”也基本上是計算型的東東。書的名氣很大,倒不
見得適合我們,還是那句話,重要的是數學思想的建立,生活在資訊社會裡我們求的是
高效,計算這玩意還是留給電腦吧。不過現在多用的似乎是複旦大學的《數學分析》
也是很好的教材。

中國的所謂高等代數,就等於線性代數加上一點多項式理論。我以為這有好的一面,因
為可以讓學生較早感覺到代數是一種結構,而非一堆矩陣翻來覆去。這裡不得不提南京
大學林成森,盛松柏兩位老師編的“高等代數”,感覺相當舒服。此書相當全面地包含
了關於多項式和線性代數的基本初等結果,同時還提供了一些有用的又比較深刻的內
容,如Sturm序列,Shermon-Morrison公式,廣義逆矩陣等等。可以說,作為本科生如能
吃透此書,就可以算高手。國內較好的高等代數教材還有清華電腦系用的那本,清華
出版社出版,書店裡多多,一看就知道。從抽象代數的觀點來看,高等代數裡的結果不
過是代數系統性質的一些例子而已。莫宗堅先生的《代數學》裡,對此進行了深刻的討
論。然而莫先生的書實在深得很,作為本科生恐怕難以接受,不妨等到自己以後成熟了
一些再讀。

正如上面所論述的,電腦系的學生學習高等數學:知其然更要知其所以然。你學習的
目的應該是:將抽象的理論再應用於實踐,不但要掌握題目的解題方法,更要掌握解題
思想,對於定理的學習:不是簡單的應用,而是掌握證明過程即掌握定理的由來,訓練
自己的推理能力。只有這樣才達到了學習這門科學的目的,同時也縮小了我們與數學系
的同學之間思維上的差距。

機率論與數理統計這門課很重要,可惜大多數院校講授這門課都會少些東西。少了的東
西現在看至少有隨機過程。到畢業還沒有聽說過Markov過程,此乃電腦系學生的恥
辱。沒有隨機過程,你怎麼分析網路和分布式系統?怎麼設計隨機化演算法和協議?據說
清華電腦系開有“隨機數學”,早就是必修課。另外,離散機率論對電腦系學生來
說有特殊的重要性。而我們國家工程數學講的都是連續機率。現在,美國已經有些學校
開設了單純的“離散機率論”課程,乾脆把連續機率刪去,把離散機率講深些。我們不
一定要這麼做,但應該更加強調離散機率是沒有疑問的。這個工作我看還是儘早的做為
好。

計算方法學(有些學校也稱為數學分析學)是最後一門由數理學院給我們開的課。一般
學生對這門課的重視程度有限,以為沒什麼用。不就是照套公式嘛!其實,做圖形映像
可離不開它,密碼學搞深了也離不開它。而且,在很多科學工程中的應用計算,都以數
值的為主。這門課有兩個極端的講法:一個是古典的“數值分析”,完全講數學原理和
演算法;另一個是現在日趨流行的“科學與工程計算”,乾脆教學生用軟體包編程。我個
人認為,電腦系的學生一定要認識清楚我們電腦系的學生為什麼要學這門課,我是
很偏向於學好理論後用電腦實現的,最好使用C語言或C++編程實現。向這個方向努力
的書籍還是挺多的,這裡推薦大家高等教育出版社(CHEP)和施普林格出版社
(Springer)聯合出版的《計算方法(Computational Methods)》,華中理工大學數學系
寫的(現華中科技大學),這方面華科大做的工作在國內應算是比較多的,而個人認為
以這本最好,至少程式設計方面涉及了:任意數學函數的求值,方程求根,線性方程組
求解,插值方法,數值積分,場微分方程數值求解。李慶揚的那本則理論性過強,與實
際應用結合得不太緊。

每個學校本系裡都會開一門離散數學,涉及集合論,圖論,和抽象代數,數理邏輯。不
過,這麼多內容擠在離散數學一門課裡,是否時間太緊了點?另外,電腦系學生不懂
組合和數論,也是巨大的缺陷。要做理論,不懂組合或者數論吃虧可就太大了。從理想
的狀態來看,最好分開六門課:集合,邏輯,圖論,組合,代數,數論。這個當然不現
實,因為沒那麼多課時。也許將來可以開三門課:集合與邏輯,圖論與組合,代數與數
論。(這方面我們學校已經著手開始做了)不管課怎麼開,學生總一樣要學。下面分別
談談上面的三組內容。
古典集合論,北師大出過一本《基礎集合論》不錯。 數理邏輯,中科院軟體所陸鐘萬教
授的《面向電腦科學的數理邏輯》就不錯。現在可以找到陸鐘萬教授的講課錄影,
http://www.cas.ac.cn/html/Dir/2001/11/06/3391.htm自己去看看吧。總的來說,學集
合/邏輯起手不難,普通高中生都能看懂。但越往後越感覺深不可測。

學完以上各書之後,如果你還有精力興趣進一步深究,那麼可以試一下GTM系列中的
《Introduction to Axiomatic Set Theory》和《A Course of Mathematical
Logic》。這兩本都有世界圖書出版社的引進版。你如果能搞定這兩本,可以說在邏輯方
面真正入了門,也就不用再浪費時間聽我瞎侃了。

據說全中國最多隻有三十個人懂圖論。此言不虛。圖論這東東,技巧性太強,幾乎每個
問題都有一個獨特的方法,讓人頭痛。不過這也正是它魅力所在:只要你有創造性,它
就能給你成就感。我的導師說,圖論裡面隨便揪一塊東西就可以寫篇論文。大家可以體
會裡面內容之深廣了吧!國內的圖論書中,王樹禾老師的“圖論及其演算法”非常成功。
一方面,其內容在國內教材裡算非常全面的。另一方面,其對演算法的強調非常適合計算
機系(本來就是科大電腦系教材)。有了這本書為主,再參考幾本翻譯的,如Bondy &
Murty的《圖論及其應用》,人民郵電出版社翻譯的《圖論和電路網路》等等,就馬馬虎
虎,對本科生足夠了。再進一步,世界圖書引進有GTM系列的"Modern Graph Theory"。
此書確實經典!國內好象還有一家出版了個翻譯版。不過,學到這個層次,還是讀原版
好。搞定這本書,也標誌著圖論入了門。

離散數學方面我們北京工業大學實驗學院有個世界級的專家,叫邵學才,複旦大學機率
論畢業的,教過高等數學,線性代數,機率論,最後轉向離散數學,出版著作無數,論
文集新加坡有一本,堪稱經典,大家想學離散數學的真諦不妨找來看看。這老師的課我
專門去聽過,極為經典。不過你要從他的不經意的話中去挖掘精髓。在同他的交談當中
我又深刻地發現一個問題,雖說邵先生寫書無數,但依他自己的說法每本都差不多,我
實在覺得詫異,他說主要是有大綱的限制,不便多寫。這就難怪了,很少聽說國外寫書
還要依據個什麼大綱(就算有,內容也寬泛的多),不敢越雷池半步,這樣不是看誰的
都一樣了。外版的書好就好在這裡,最新的科技成果裡面都有論述,別的先不說,至少
是“緊跟時代的理論知識”。

組合感覺沒有太適合的國產書。還是讀Graham和Knuth等人合著的經典“具體數學”吧,
西安電子科技大學出版社有翻譯版。 抽象代數,國內經典為莫宗堅先生的“代數學”。
此書是北大數學系教材,深得好評。然而對本科生來說,此書未免太深。可以先學習一
些其它的教材,然後再回頭來看“代數學”。國際上的經典可就多了,GTM系列裡就有一
大堆。推薦一本談不上經典,但卻最簡
單的,最容易學的:http://www.math.miami.edu/~ec/book/這本“Introduction to
Linear and Abstract Algebra"非常通俗易懂,而且把抽象代數和線性代數結合起來,
對初學者來說非常理想,我校比較牛的同學都有收藏。

數論方面,國內有經典而且以困難著稱的”初等數論“(潘氏兄弟著,北大版)。再追溯
一點,還有更加經典(可以算世界級)並且更加困難的”數論導引“(華羅庚先生的名著,
科學版,九章書店重印,繁體的看起來可能比較困難)。把基礎的幾章搞定一個大概,對
本科生來講足夠了。但這隻是初等數論。本科畢業後要學計算數論,你必須看英文的
書,如Bach的"Introduction to Algorithmic Number Theory"。
電腦科學理論的根本,在於演算法。現在很多系裡給本科生開設演算法設計與分析,確實
非常正確。環顧西方世界,大約沒有一個三流以上電腦系不把演算法作為必修的。演算法
教材目前公認以Corman等著的"Introduction to Algorithms"為最優。對入門而言,這
一本已經足夠,不需要再參考其它書。

再說說形式語言與自動機。我看過北郵的教材,應該說寫的還清楚。但是,有一點要強
調:形式語言和自動機的作用主要在作為計算模型,而不是用來做編譯。事實上,編譯
前端已經是死領域,沒有任何open problems,北科大的班曉娟博士也曾經說過,編譯的
技術已相當成熟。如果為了這個,我們完全沒必要去學形式語言--用用yacc什麼的就完
了。北郵的那本在國內還算比較好,但是在深度上,在跟可計算性的聯絡上都有較大的
局限,現代感也不足。所以建議有興趣的同學去讀英文書,不過國內似乎沒引進這方面
的教材。可以去互動出版網上看一看。入門以後,把形式語言與自動機中定義的模型,
和數理邏輯中用遞迴函式定義的模型比較一番,可以說非常有趣。現在才知道,什麼叫
“宮室之美,百官之富”!

電腦科學和數學的關係有點奇怪。二三十年以前,電腦科學基本上還是數學的一個
分支。而現在,電腦科學擁有廣泛的研究領域和眾多的研究人員,在很多方面反過來
推動數學發展,從某種意義上可以說是孩子長得比媽媽還高了。但不管怎麼樣,這個孩
子身上始終流著母親的血液。這血液是the mathematical underpinning of computer
science(電腦科學的數學基礎),也就是理論電腦科學。原來在東方大學城圖書館中
曾經看過一本七十年代的譯本(書皮都沒了,可我就愛關注這種書),大概就叫《計算
機數學》。那本書若是放在當時來講決是一本好書,但現在看來,涵蓋的範圍還算廣,
深度則差了許多,不過推薦大一的學生倒可以看一看,至少可以使你的計算數學入入
門。

最常和理論電腦科學放在一起的一個詞是什嗎?答:離散數學。這兩者的關係是如此
密切,以至於它們在不少場合下成為同義字。(這一點在前面的那本書中也有體現)傳
統上,數學是以分析為中心的。數學系的同學要學習三四個學期的數學分析,然後是複
變函數,實變函數,泛函數等等。實變和泛函被很多人認為是現代數學的入門。在物
理,化學,工程上應用的,也以分析為主。

隨著電腦科學的出現,一些以前不太受到重視的數學分支突然重要起來。人們發現,
這些分支處理的數學對象與傳統的分析有明顯的區別:分析研究的問題解決方案是連續
的,因而微分,積分成為基本的運算;而這些分支研究的對象是離散的,因而很少有機
會進行此類的計算。人們從而稱這些分支為“離散數學”。“離散數學”的名字越來越
響亮,最後導致以分析為中心的傳統數學分支被相對稱為“連續數學”。

離散數學經過幾十年發展,基本上穩定下來。一般認為,離散數學包含以下學科:
1) 集合論,數理邏輯與元數學。這是整個數學的基礎,也是電腦科學的基礎。
2) 圖論,演算法圖論;組合數學,組合演算法。電腦科學,尤其是理論電腦科學的核心

演算法,而大量的演算法建立在圖和組合的基礎上。
3) 抽象代數。代數是無所不在的,本來在數學中就非常重要。在電腦科學中,人們驚
訝地發現代數竟然有如此之多的應用。

但是,理論電腦科學僅僅就是在數學的上面加上“離散”的帽子這麼簡單嗎?一直到
大約十幾年前,終於有一位大師告訴我們:不是。D.E.Knuth(他有多偉大,我想不用我
廢話了)在Stanford開設了一門全新的課程Concrete Mathematics。 Concrete這個詞在
這裡有兩層含義:
首先:對abstract而言。Knuth認為,傳統數學研究的對象過於抽象,導致對具體的問題
關心不夠。他抱怨說,在研究中他需要的數學往往並不存在,所以他只能自己去創造一
些數學。為了直接面嚮應用的需要,他要提倡“具體”的數學。在這裡我做一點簡單的
解釋。例如在集合論中,數學家關心的都是最根本的問題--公理系統的各種性質之類。
而一些具體集合的性質,各種常見集合,關係,映射都是什麼樣的,數學家覺得並不重
要。然而,在電腦科學中應用的,恰恰就是這些具體的東西。Knuth能夠首先看到這一
點,不愧為當世電腦第一人。其次,Concrete是Continuous(連續)加上discrete(離
散)。不管連續數學還是離散數學,都是有用的數學!

理論與實際的結合——電腦科學研究的範疇
前面主要是從數學角度來看的。從電腦角度來看,理論電腦科學目前主要的研
究領域包括:可計算性理論,演算法設計與複雜性分析,密碼學與資訊安全,分散式運算
理論,並行計算理論,網路理論,生物資訊計算,計算幾何學,程式語言理論等等。這
些領域互相交叉,而且新的課題在不斷提出,所以很難理出一個頭緒來。想搞搞這方面
的工作,推薦看中國電腦學會的一系列書籍,至少代表了我國的權威。下面隨便舉一
些例子。
由於應用需求的推動,密碼學現在成為研究的熱點。密碼學建立在數論(尤其是計算
數論),代數,資訊理論,機率論和隨機過程的基礎上,有時也用到圖論和組合學等。很多
人以為密碼學就是加密解密,而加密就是用一個函數把資料打亂。這樣的理解太淺顯
了。
現代密碼學至少包含以下層次的內容:
第一,密碼學的基礎。例如,分解一個大數真的很困難嗎?能否有一般的工具證明協議
正確?
第二,密碼學的基本課題。例如,比以前更好的單向函數,簽名協議等。
第三,密碼學的進階問題。例如,零知識證明的長度,秘密分享的方法。
第四,密碼學的新應用。例如,數字現金,叛徒追蹤等。
在分布式系統中,也有很多重要的理論問題。例如,進程之間的同步,互斥協議。一個
經典的結果是:在通訊通道不可靠時,沒有確定型演算法能實現進程間協同。所以,改進
TCP三向交握幾乎沒有意義。例如時序問題。常用的一種序是因果序,但因果序直到不久
前才有一個理論上的結果....例如,死結沒有實用的方法能完美地對付。例如,......操
作系統研究過就自己去舉吧!
如果電腦只有理論,那麼它不過是數學的一個分支,而不成為一門獨立的科學。
事實上,在理論之外,電腦科學還有更廣闊的天空。

我一直認為,4年根本不夠學習電腦的基礎知識,因為面太寬了......
這方面我想先說說我們系在各校普遍開設的《電腦基礎》。在高等學校開設《計
算機基礎課程》是我國高教司明文規定的各專業必修課程要求。主要內容是使學生初步
掌握電腦的發展曆史,學會簡單的使用作業系統,文文書處理,表格處理功能和初步的
網路應用功能。但是在電腦科學系教授此門課程的目標決不能與此一致。在電腦系
課程中目標應是:讓學生較為全面的瞭解電腦學科的發展,清晰的把握電腦學科研
究的方向,發展的前沿即每一個課程在整個學科體系中所處的地位。搞清各學科的學習
目的,學習內容,應用領域。使學生在學科學習初期就對整個學科有一個整體的認識,
以做到在今後的學習中清楚要學什麼,怎麼學。電腦基本應用技能的位置應當放在第
二位或更靠後,因為這一點對於本系的學生應當有這個摸索能力。這一點很重要。推薦
給大家一本書:機械工業出版社的《電腦文化》(New Perspective of Computer
Science),看了這本書我才深刻的體會到自己還是個電腦科學初學者,才比較透徹的
瞭解了什麼是電腦科學。另外在廈門大學趙致琢老師的著作《計算科學導論》當中的
很多經典理論都是在同類書籍中很難找到的。看看他也許你才會明白一個最基本的問
題:為什麼電腦科學叫計算科學更為準確。這本書在世界上也可成為精品級的著作。

一個一StreamCompute機系的優秀學生決不該僅僅是一個編程高手,但他一定首先是一個編程高
手。我上大學的時候,第一門專業課是C語言程式設計,念電腦的人從某種角度講相當
一部分人是靠寫程式吃飯的。在我們北京工業大學實驗學院電腦系裡一直有這樣的爭
論(時至今日CSDN上也有),關於第一程式設計語言該用哪一種。我個人認為,用哪種
語言屬於末節,關鍵在養成良好的編程習慣。當年老師對我們說,打好基礎後學一門新
語言只要一個星期。現在我覺得根本不用一個星期,前提是先把基礎打好。不要再猶豫
了,學了再說,等你抉擇好了,別人已經會了幾門語言了。

組合語言和微機原理是兩門特煩人的課。你的數學/理論基礎再好,也占不到什麼便宜。
這兩門課之間的次序也好比先有雞還是先有蛋,無論你先學哪門,都會牽扯另一門課裡
的東西。所以,只能靜下來慢慢琢磨。這就是典型的工程課,不需要太多的聰明和頓
悟,卻需要水滴石穿的漸悟。有關這兩門課的書,電腦書店裡不難找到。弄幾本最新
的,對照著看吧。組成原理推薦《電腦群組成與結構》清華大學王愛英教授寫的。彙編
語言大家拿8086/8088入個門,之後一定要學80x86組合語言。實用價值大,不落後,結
構又好,寫寫高效病毒,進階語言裡嵌一點彙編,進行底層開發,總也離不開他,推薦
清華大學沈美明的《IBM—PC組合語言程式設計》。有些人說不想瞭解電腦體繫結構,
也不想製造電腦,所以諸如電腦原理,組合語言,介面之類的課覺得沒必要學,這
樣合理嗎?顯然不合理,這些東西遲早得掌握,肯定得接觸,而且,這是電腦專業與
其他專業學生相比的少有的幾項優勢。做項目的時候,瞭解這些是非常重要的,不可能
說,僅僅為了技術而技術,只懂技術的人最多做一個編碼工人,而永遠不可能全面地了
解整個系統的設計,而編碼工人是越老越不值錢。關於組成原理還有個講授的問題,在
我學這門課程時老師講授時把CPU工作原理譽微程式設計這一塊略掉了,理由是我們國家
搞CPU技術不如別的國家,搞了這麼長時間好不容易出了個龍芯比Intel的還差個十萬八
千裡,所以建議我們不要學了。我看這在各校也未見得不是個問題吧!若真是如他所
說,那中國的電腦科學哪個方向都可以停了,軟硬體,應用,有幾項搞得過美國,搞
不過別人就不搞了,那我們坐在這裡幹什嗎?教學的觀念需要轉變的。

類比電路這東東,如今不僅電腦系學生搞不定,電子系學生也多半害怕。如果你真想
軟硬體通吃,那麼建議你先看看邱關源的“電路原理”,也許此後再看類比電路底氣會
足些。教材:康華光的“電子技術基礎”(高等教育出版社)還是不錯的(我校電子系
在用)。有興趣也可以參考童詩白的書。

數字電路比類比電路要好懂得多。推薦大家看一看我們北工大劉英嫻教授寫的《數字邏
輯》業績人士都說這本書很有參考價值(機械工業出版社的)。原因很明了,實用價值
高,能聽聽她講授的課程更是有一種“享受科學”的感覺。清華大學閻石的書也算一本
好教材,遺憾的一點是整合電路講少了些。真有興趣,看一看大規模數字系統設計吧
(北航那本用的還比較多)。

電腦系統結構該怎麼教,國際上還在爭論。國內能找到的較好教材為Stallings
的"Computer Organization and Architectureesigning for Performance"(清華影印
本)。國際上最流行的則是“Computer architecture: aquantitative approach", by
Patterson & Hennessy。
作業系統可以隨便選用《作業系統的核心設計與實現》和《現代作業系統》兩書之
一。這兩部都可以算經典,唯一缺點就是理論上不夠嚴格。不過這領域屬於Hardcore
System,所以在理論上馬虎一點也情有可原。想看理論方面的就推薦清華大學出版社《操
作系統》吧,高教司司長張堯學寫的,我們教材用的是那本。 另外推薦一本《Windows
作業系統原理》機械工業出版社的,這本書是我國作業系統專家在微軟零距離考察半
年,寫作曆時一年多寫成的,教作業系統的專家除了清華大學的張堯學(現高教司司
長)幾乎所有人都參加了。Bill Gates親自寫序。裡面不但結合windows2000,xp詳述操
作系統的核心,而且後面講了一些windows編程基礎,有外版書的味道,而且上面一些內
容可以說在國內外只有那本書才有對windows核心細緻入微的介紹,
如果先把形式語言學好了,則編譯原理中的前端我看只要學四個演算法:最容易實現
的遞迴下降;最好的自頂向下演算法LL(k);最好的自底向上演算法LR(k);LR(1)的簡化SLR
(也許還有另一簡化LALR)。後端完全屬於工程性質,自然又是another story。
推薦教材:Kenneth C.Louden寫的“Compiler Construction Principles and
Practice”即是《編譯原理及實踐》(機械工業出版社的譯本)
學資料庫要提醒大家的是,會用VFP,VB, Power builder不等於懂資料庫。(這世界
上自以為懂資料庫的人太多了!)資料庫設計既是科學又是藝術,資料庫實現則是典型的
工程。所以從某種意義上講,資料庫是最典型的一門電腦課程——理工結合,互相滲
透。另外推薦大家學完軟體工程學後再翻過來看看資料庫技術,又會是一番新感覺。推
薦教材:Abraham Silberschatz等著的 "Database System Concepts".作為知識的完整
性,還推薦大家看一看機械工業出版社的《資料倉儲》譯本。

電腦網路的標準教材還是來自Tanenbaum的《Computer Networks》(清華大學有譯
本)。還有就是推薦謝希仁的《電腦網路教程》(人民郵電出版社)問題講得比較清
楚,參考文獻也比較權威。不過,網路也屬於Hardcore System,所以光看書是不夠的。
建議多讀RFC,http://www.ietf.org/rfc.htm裡可以按編號下載RFC文檔。從IP的讀起。
等到能掌握10種左右常用協議,就沒有幾個人敢小看你了。再做的工作我看放在網路設
計上就比較好了。

資料結構的重要性就不言而喻了,學完資料結構你會對你的編程思想進行一番革命性的
洗禮,會對如何建立一個合理高效的演算法有一個清楚的認識。對於演算法的建立我想大家
應當注意以下幾點:
當遇到一個演算法問題時,首先要知道自己以前有沒有處理過這種問題.如果見過,那麼你一
般會順利地做出來;如果沒見過,那麼考慮以下問題:
1. 問題是否是建立在某種已知的熟悉的資料結構(例如,二叉樹)上?如果不是,則要自己
設計資料結構。
2. 問題所要求編寫的演算法屬於以下哪種類型?(建立資料結構,修改資料結構,遍曆,尋找,
排序...)
3. 分析問題所要求編寫的演算法的數學性質.是否具備遞迴特徵?(對於遞迴程式設計,只要
設計出合理的參數表以及遞迴結束的條件,則基本上大功告成.)
4. 繼續分析問題的數學本質.根據你以前的編程經驗,設想一種可能是可行的解決辦法,
並證明這種解決辦法的正確性.如果題目對演算法有時空方面的要求,證明你的設想滿足其
要求.一般的,時間效率和空間效率難以兼得.有時必須通過建立輔助儲存的方法來節省時
間.
5. 通過一段時間的分析,你對解決這個問題已經有了自己的一些思路.或者說,你已經可
以用自然語言把你的演算法簡單描述出來.繼續驗證其正確性,努力發現其中的錯誤並找出
解決辦法.在必要的時候(發現了無法解決的矛盾),推翻自己的思路,從頭開始構思.
6. 確認你的思路可行以後,開始編寫程式.在編寫代碼的過程中,儘可能把各種問題考慮
得詳細,周密.程式應該具有良好的結構,並且在關鍵的地方配有注釋.
7. 舉一個例子,然後在紙上用筆執行你的程式,進一步驗證其正確性.當遇到與你的設想
不符的情況時,分析問題產生的原因是編程方面的問題還是演算法思想本身有問題.
8. 如果程式通過了上述正確性驗證,那麼在將其進一步最佳化或簡化。
9. 撰寫思路分析,注釋.
對於具體的演算法思路,只能靠你自己通過自己的知識和經驗來加以獲得,沒有什麼特定的
規律(否則程式員全部可以下崗了,用機器自動產生代碼就可以了).要有豐富的想象力,就
是說當一條路走不通時,不要鑽牛角尖,要敢於推翻自己的想法.我也只不過是初學者,說
出上面的一些經驗,僅供大家參考和討論。
關於人工智慧,我覺得的也是非常值得大家仔細研究的,雖然不能算是剛剛興起的
學科了,但是絕對是非常有發展前途的一門學科。我國人工智慧創始人之一,北京科技
大學塗序彥教授(這老先生是我的導師李小堅博士的導師)對人工智慧這樣定義:人工
智能是模仿、延伸和擴充人與自然的智能的技術科學。在美國人工智慧官方教育網站上
對人工智慧作了如下定義:Artificial Intelligence, or AI for short, is a
combination of computer science, physiology, and philosophy. AI is a broad
topic, consisting of different fields, from machine vision to expert
systems. The element that the fields of AI have in common is the creation of
machines that can "think".
這門學科研究的問題大概說有:
(1)符號主義: 符號計算與程式設計基礎,知識表達方法 :知識與思維,產生式規
則,語意網路,一階謂詞邏輯問題求解方法:搜尋策略,啟發學習法搜尋,搜尋演算法,問題
規約方法,謂詞演算:歸結原理,歸結過程專家系統:建立專家系統的方法及工具
(2)聯結主義(神經網路學派):1988年美國權威機構指出:資料庫,網路發展呈直線
上升,神經網路可能是解決人工智慧的唯一途徑。
我想對於人工智慧的學習,大家一定不要像學數學似的及一些現成的結論,要學會分
析問題,最好能利用程式設計實現,這裡推薦給大家ACM最佳博士論文獎獲得者塗曉媛博
士的著作《人工魚—電腦動畫的人工生命方法》(清華大學出版社)。搞人工生命的
同學不會不知道國際知名的塗氏父女吧。關於人工智慧的書當然首選《Artificial
Intelligence A New Synthesis》Nils J.Nilsson.鼻祖嘛!
關於網路安全我也想在這裡說兩句,隨著電腦技術的發展,整個社會的資訊化水平突
飛猛進,電腦網路技術日新月異,網路成了當即社會各個工作領域不可缺少的組成部
分,只要有網路存在,網路安全問題就是一個必須解決好的問題,學習網路安全不是簡
簡單單的收集一些駭客工具黑一黑別人的網站,而是要學習他的數學原理,實現原理,
搞清底層工作機制,這樣才能解決大部分的現有問題和新出現的安全問題。

關於電腦科學的一些邊緣科學我想談一談軟體工程技術,對於一個企業,推出軟體是
不是就是幾個程式員坐在一起,你寫一段程式,我寫一段程式呢?顯然不是。軟體工程
是典型的電腦科學和數學,管理科學,心理學,社會學等學科的綜合。它使我們這些
搞理論和技術的人進入了一個社會。你所要考慮的不僅僅是程式的優劣,更應該考慮程
序與軟體的區別,軟體與軟體產品的區別,軟體軟體產品的市場前景,如何去更好的與
人交流。這方面我還在學習階段,以後這方面再寫文章吧,先推薦給大家幾本書:暢銷
20年不衰的《人月神話》(清華大學中文版,中國電力出版社影印版),《軟體工程-實
踐者研究的方法》(機械工業出版社譯本),《人件》(據說每一位微軟公司的部門經
理都讀過這本書,推薦老總們和想當老總的同學都看看,瞭解一下什麼是軟體企業中的
人)以及微軟公司的《軟體開發的科學與藝術》和《軟體企業的管理與文化》(研究軟
件企業的制勝之道當然要研究微軟的成功經驗了!)

關於電腦技術的學習我想是這樣的:學校開設的任何一門科學都有其滯後性,不要總
認為自己掌握的某門技術就已經是天下無敵手了,雖然現在Java,VB,C,C++用的都很多,
怎能保證沒有被淘汰的一天,我想.NET平台的誕生和X#語言的初見端倪完全可以說明問
題。換言之,在我們掌握一門新技術的同時就又有更新的技術產生,身為當代的大學生
應當有緊跟科學發展的素質。舉個例子,就像有些同學總說,我做網頁設計就喜歡直接
寫html,不願意用什麼Frontpage,Dreamweaver。能用語言寫網頁固然很好,但有高效的
手段你為什麼不使呢?僅僅是為了顯示自己的水平高,unique? 我看真正水平高的是能
夠以最快的速度接受新事物的人。進階程式設計語言的發展日新月異,今後的程式設計
就像人們在說話一樣,我想大家從xml中應是有所體會了。難道我們真就寫個什麼都要用
彙編,以顯示自己的水平高,真是這樣倒不如直接用機器語言寫算了。反過來說,想要
以最快的速度接受並利用新技術關鍵還是在於你對電腦科學地把握程度。

電腦技術牽扯的內容更為廣泛些,一項一項說恐怕沒個一年半載也說不清。我只想提
醒大家的還是那句話,技術與科學是不能分家的,學好了科學同時搞技術,這才是上上
策。猶如英語,原先人們與老外交流必須要個翻譯,現在滿馬路的人都會說英語。就連
21世紀英語演講比賽的冠軍都輪不到英語系的學生了。電腦也是一樣的,我們必須面
對的一個現實就是:電腦真就只是一個工具,如果不具備其它方面的素養,電腦系
的學生雖然不能說找不到工作,不過總有一天當其他專業性人才掌握了電腦技術後將
比我們出色許多。原因就在於電腦解決的大都是實際問題,實際問題的知識卻是我們
少有的。單一的電腦技術沒有立足之地。
我想是時候指出:學習每一個課程之前,都要先搞清這一課程的學習目的。這一學
科的應用領域。據我自身所瞭解到的同齡同學和低年級的同學的學習狀況:他們之中很
少有人知道學一個學科的學習目的,期末考試結束了也不知道學這科做什麼用。這就失
去了讀電腦科學的意義。當然這與現存的教育思想不能說一點關係都沒有。
總的來說,從教育角度來講,國內高校的課程安排不是很合理,強調理論,又不願意在
理論上深入教育,無力接受新技術,想避開新技術又無法避得一乾二淨。我覺得關鍵問
題就是國內的高校難於突破現狀,條條框框限制著怎麼求發展。我們雖然認識得到國外
教育的優越性,但為什麼遲遲不能採取行動?哪怕是去粗取精的取那麼一點點。我們需
要改變。從我們自身角度來講,多數人4年下來既沒有學習電腦科學的學術水平,也沒
有學習電腦技術的那種韌勁。在我剛上大一時,我的電腦科學入門導師,淮北煤炭
師範學院王愛平教授曾經對我說過這樣一番話:“當你選擇了電腦這一門科學,就意
味著你踏上了一條不歸路,就意味著你一生都要為之奮鬥……你的身後是懸崖,只有向
前走,不能往後退。”
有些同學說按照這樣學習學的東西太多,有的未見得有用,我想打個形象的比方:
學校學出來的人都是一個球體,方方面面的知識都應具備。可是社會上需要球體的地方
很少,反而需要的是磚和瓦,即精通某一行的人才。但是對於同等體積的物體,用球體
來改造是最方便最省事的。學校的學生很多,為了能夠使更多的學生來適應這個社會,
學校也就不得以把所有的學生都打造成一個球體,然後讓社會對這些學生進行再加工,
成為真正能夠有用的人才。即使你非常清楚自己的將來要幹什麼,並且非常下定決心要
走自己的路,這一步你也必須走,世界是在不斷變化的,你不能預料未來。想清楚,努
力去幹吧!
必須結束這篇“胡侃”了,再侃下去非我力所能及。其實電腦還有很多基礎課都值得
一侃。怎奈我造詣有限,不敢再讓內行恥笑。對於博大精深的電腦科學,我只能說我
永遠都是個Beginner.最後聲明:這些只針對本科階段的學習。即使把這些全弄通了,前
面的路還長,電腦科學需要我們為之奮鬥......學習電腦科學需要韌性,更需要創
新,需要激情。深刻學習理論知識,勇於接受新技術的挑戰,這才是我們這一代人應具
有的素質。最後送大家一句話“Wake up every day with a feeling of passion for
the difference technology will make in people's life!”。

在我大一時無意中找到了南京大學網友sir的文章“胡侃(理論)電腦學習”,這個帖
子對我的大學生活起了至關重要的作用,也因此同他成為了好友,本文章在原有文章的
基礎上改進了其中我認為不太合適的理論,修正了一些觀點,在推薦教材方面結合我的
學習情況有了較大改變。值得一提的是增加了一些電腦理論的內容,電腦技術的內
容結合我國的教學情況和我們學習的實際情況進行了重寫。感謝大家的支援,這篇文章
才能比較快的完成,這裡也只是寫下了我在學習電腦科學時的所思所想,很不成熟。
與原文相比增加了一些推薦參考書,刪去了一些過陳舊的難以找到的材料。並且對一些
問題作了更為詳細地闡述,也增加了一些新觀點。希望大家多多討論,改進不足,讓我
們共同努力吧!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.