软件工程师之路——一个老软件工程师对刚下大学的学弟学妹的忠告

程序员之路——一个老程序员对刚上大学的学弟学妹的忠告

始终认为,对一个初学者来说,IT界的技术风潮是不可追赶。 我时常看见自己的DDMM们把课本扔了,去买些价格不菲的诸如C#, VB.Net 这样的大部头,这让我感到非常痛心。 而许多搞不清指针是咋回事的BBS站友眉飞色舞的讨论C#里面可以不用指针等等则让我觉得好笑。

C#就象当年的ASP 一样,“忽如一夜春风来,千树万树梨花开”,结果许多学校的信息学院成了“Web 学院”。 96, 97级的不少大学生都去做Web了。当然我没有任何歧视某一行业的意识。 我只是觉得如果他们把追赶这些时髦技术的时间多花一点在基础的课程上应该是可以走得更远的

几个误区

初学者对C#风潮的追赶其实也只是学习过程中经常遇到的几个误区之一。 我将用一些实际的例子来说明这些现象,你可以按部就班的看看自己是不是属于其中的一种或者几种:

认为计算机技术等于编程技术:

有些人即使没有这个想法,在潜意识中也有这样的冲动。 让我奇怪的是,许多信息学院的学生也有这样的念头。 认为计算机专业就是编程专业,与编程无关的,或者不太相关课程他统统都不管,极端的学生只要书上没带“编程”两个字他就不看。

其实编程只是计算机技术应用过程中一种复杂性最低的劳动,这就是为什么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的编程)来说甚至是不可或缺的。

一个活生生的例子是我和我的一个同学,在大一时我还找不到开机按纽,他已经会写些简单的汇编程序了。 我把大二的所有时间花在了汇编,计算机体系结构,数据结构,操作系统原理等等这些课程的学习上,而他则开始学习HTML和VB,并追赶ASP的潮流。 大三的时候我开始学习Windows 操作系统原理,学习SDK编程,时间是漫长的,这时我才能够用VC开发出象模象样的应用程序。 我曾一度因为同学的程序已经能够运行而自己还在学习如何创建对话框而懊恼不已,但临到毕业才发现自己的选择是何等的正确。 和我谈判的公司开出的薪水是他的两倍还多。

下面有一个不很恰当的比方:假设学习VB编程需要 4个月,学习基础课程和VC的程序设计需要1年。 那么如果你先学VB,再来学习后者,时间不会减少,还是1年,而反过来,如果先学习后者,再来学VB,也许你只需要1个星期就能学得非常熟练。

几个重要的基础课程

如果你是学生,或者如果你有充足的时间。我建议你仔细的掌握下面的知识。 我的建议是针对那些希望在IT技术上有所成就的初学者。 同时我还列出了一些书目,这些书应该都还可以在书店买到。 说实在的,我在读其他人的文章时最大的心愿就是希望作者列出一个书单。

大学英语 -不要觉得好笑。我极力推荐这门课程是因为没有专业文档的阅读能力是不可想象的。 中文的翻译往往在猴年马月才会出来,而现在的许多出版社干脆就直接把E文印刷上去。 学习的方法是强迫自己看原版的教材,开始会看不懂,用多了自然熟练。 吃得苦下得狠心绝对是任何行业都需要的品质

计算机体系结构和汇编语言 -关于体系结构的书遍地都是,而且也大同小异, 倒是汇编有一本非常好的书《80x86汇编语言程序设计教程》(清华大学出版社,黑色封面,杨季文著)。 你需要着重学习386后保护模式的程序设计。否则你在学习现代操作系统底层的一些东西的时候会觉得是在看天书。

计算机操作系统原理 -我们的开发总是在特定的操作系统上进行,如果不是,只有一种可能:你在自己实现一个操作系统。 无论如何,操作系统原理是必读的。这就象我们为一个芯片制作外围设备时,芯片基本的工作时序是必需了解的。 这一类书也很多,我没有发现哪一本书非常出众。 只是觉得在看完了这些书后如果有空就应该看看《Inside 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页的速度掌握其要领。 尽可能多的在计算机上实践一种理论或者算法。

日三省乎己

每天读的书太多,容易让人迷失方向。看看我以前整理的一个合格程序员应该看哪些书,如果原文被墙,可以到****看。 一定要在每天晚上想想自己学了些什么,还有些什么相关的东西需要掌握,自己对什么最感兴趣,在一本书上花的时间太长还是不够等等。 同时也应该多想想未来最有可能出现的应用,这样能够让你不是追赶技术潮流而是引领技术潮流。 同时,努力使用现在已经掌握的技术和理论去制作具有一定新意的东西。 坚持这样做能够让你真正成为一个软件“研发者”而不仅仅是一个CODER

把最多的时间花在学习上

这是对初学者最后的忠告。 把每个星期玩CS或者CS的时间压缩到最少,不玩它们是最好的。 同时,如果你的ASP技术已经能够来钱,甚至有公司请你兼职的话,这就证明你的天分能够保证你在努力的学习之后取得更好的收益,你应该去做更复杂的东西。 眼光放长远一些,这无论是对谁都是适用的。

38楼yisshengyouni1小时前
支持,希望正在学习的同学好好学习
37楼tianyazaiheruan1小时前
学习了。。不错。。只是推荐的课程都是不能直接工作用的、、、因为没有一门具体的语言
36楼TonyJiang081小时前
你的很多观点我赞成,但是说的:“不少大师级的计算机技术研究者是不懂编程的???”,这句话值得推敲,计算机是图灵提出的,冯诺依曼提出了现代计算机的结构模型,最重要的就是内存的概念,使计算机能通过编程,低成本的解决问题,如果学计算机不懂编程,感觉就是白学了,而且就算你是设计软件算法,不写代码,也要涉及空间复杂度的概念,我的观念是不懂编程,就不懂计算机的真谛。
35楼wjb_yd1小时前
说的很好,引起了一些共鸣。
34楼masikkk2小时前
说得好啊,近来我的感受也是如此。
33楼rixingrixing2小时前
“死抠C++的语法就和孔已己炫耀茴香豆的茴字有几种写法一样毫无意义。 你根本不需要对的C++语法太关心,动手编程就是了,有不记得的地方一查MSDN就立马搞定。 我有个结论就是,实际的开发过程中对程序语法的了解是最微不足道的知识。”n说的太好了!
Re: JustJavaC2小时前
回复rixingrixingn面试官问:“ i = 2; ++--i--++;结果是多少?”n某人答:“尊敬的考官,我开发过程中,绝对不会写出这样的代码”。n录取。
32楼xinghun613小时前
楼主写得不错,赞一个。n个人也强烈推荐Windows程序设计,学完C后可以立即学这个,可以说学完C只能写Dos程序,学完这本书,就可以写出像模像样的桌面程序了
31楼wdongnian3小时前
是的 必须要有基础学科的支撑 操作系统建议看 操作系统 精髓于设计原理
30楼xbsoar3小时前
希望LZ多发表一些这样的文章,虽然我已经毕业了但还是有收获
29楼smoking_no3小时前
O(∩_∩)O谢谢楼主的无私奉献,学习是重要的学习方法却更重要.我们真不要做名副其实的CODER
28楼Kid_U_ForFun3小时前
偶觉得偶最重要的是随风静止,沉淀。
27楼majianwei07054小时前
顶起,总结的真好
26楼ybattle4小时前
工作之后才知基础最重要
25楼huyahoo4小时前
受教了
24楼jadechen199109094小时前
我正是LZ说的那种情况,学习啊,大三了,感觉好多东西都没学到,悲剧。。。。还是先静下心来把教程看完吧
23楼whimsyChen5小时前
想再补充点,不只英语重要,还有数学!数学分析,离散数学,概率论..等等...其实英语和数学都是越强越好的
22楼KKT1155小时前
谢谢楼主 学习了
21楼xi52qian5小时前
顶!现在回头看来,我很后悔大学时候没学好那些课!
20楼ho112233445小时前
选择之前,问清自己,真的是自己的兴趣吗?
19楼gongzhe20115小时前
SB
18楼Justme06小时前
其实我很久就看过这篇文章,非常赞同这句话:一个并未进入到行业竞争中来的初学者最大的资本便是他有足够的时间沉下心来学习基础性的东西,学习why而不是how。
Re: quanben6小时前
回复Justme0n嗯,我也赞同。光阴最为宝贵。
17楼xfht20116小时前
我是个初学者,语言学的挺多,现在主学java方向,ssh框架是学校的主流课程,我想知道现在java方面还有什么技术,比如android?
16楼yudahai1096小时前
我有点不同意见,如果你仅仅学那些基础课程,短期内看不到自己的成就,就逐渐失去兴趣了。在软件这个行业,如果你没兴趣,还有毅力学下去,我不得不佩服你。n反而我觉得22楼说的有点道理的,你学java、C#能很快的看到自己写的小程序,很有成就感。做项目过程中,不停的遇到问题,能促使你回头看C++、操作系统原理、 linux核等,这时候你带着问题去看,反而不需要刻意的去记忆。n学东西的过程都是由简入难,如果一开始就很枯燥,我想很多人都望而却步了。。。n当然每个人都有自己的学习方法,不必强求。。
Re: JustJavaC6小时前
回复yudahai109n将基础知识打牢和盲目的学习基础知识不一样。nn『先把基础打牢,然后再赶时髦』!
15楼czjuttsw15小时前
可能是我阅历尚浅,无法支持你的看法。n试问一下,就拿你讲的网络原理,如果不记住一些基本的数据,你以前是怎么通过考试的?另外做笔记的确是一个良好的习惯,它可以加深你的印象,而且是不分专业科目的。n还有就是在学习计算机的时候,我都喜欢从实践到理论,从实质到抽象,可能是我太笨了吧,不过不是大多数人都能立即懂得抽象的东西,所以,我觉得有时候是应该死抠细节,弄明白了原理,再回过头来看看宏观,一切就明了了
Re: peter1980121014小时前
回复czjuttswn网线头的排线顺序,你还记得么?n你记住这个顺序用了多长时间?n这个顺序能变么?nn上学的时候我没背过,实在记不住啊,后来工作了,有一次做了30根网线,一下就记住了。n再反过头来想想当时书上的意思,一下就明白了,顺序根本不重要,只要两头排序一致就能通了。n再后来压4根线就够了,因为知道怎么用了。n现在想想,大学的课程就像是一个一点武功都不懂的人在学九阴真经和乾坤大挪移一样,太晦涩难懂了。
Re: czjuttsw9小时前
回复peter19801210n对啊,今天刚上JAVAEE,老师就说学校本来就不情愿开设这门技术课,更多的是给我们讲解一些设计思想之类的抽象东西。但是考虑到实际情况,因为有些同学要参加工作,所以没办法还是开设了JAVAEE,真是搞不懂。大学学了那么多理论东西,到头来去找工作却处处碰壁。
Re: zw9467小时前
回复czjuttswn对,这就是叫应试教育。实际操作能力差的要命,到头来理论知识掌握的还不错,可惜就是找不到工作。
14楼quanben昨天 23:56
关于第二点和第四点想补充几句。以前我也有这样的感觉,但现在看来越来越不那么简单。n编程虽然底层,但编程是基础。大师不知道,但是国内外很多牛人都是编程牛人。任何思想、架构和理论都要诉诸于好的编程实现才完整,同时思想、架构和理论也和程序语言有密切的关系。脱离编程和语言谈计算机科学技术是空中楼阁,从今往后这个趋势也会越来越明显。n虽然盲目追求肤浅的时兴技术是很愚蠢的,也影响到在大学里打基础,但是不等于不该去了解,不该去探讨技术发展的趋势和规律这些大学里学不到或很难学到的真正高深的东西。这也是避免在大学里死学造成的孔乙己作风。n同意您说的打好基础,按需学习的理论。
13楼llywq昨天 23:43
确实是忠告啊!
12楼Monster1昨天 23:24
混口饭吃,的路过
11楼linexus昨天 22:39
对汇编一点兴趣都没有。。。。这个不要紧吧。。以后也不打算看了
Re: quanben昨天 22:45
回复linexusn了解了解就可以了。黄金准则,没有兴趣,就做了解。
10楼itwangpan昨天 21:15
每天读的书太多,容易让人迷失方向。
9楼JustJavaC昨天 21:04
[quote=aofengdaxia]事实上我不完全认同你的说法,很多计算机毕业的学生并不能有效的走上对口的岗位,导致计算机行业失业率最高...[/quote]n三言两语回复不了,只能又写了篇博客。http://justjavac.com/other/2012/09/21/why-are-you-so-low-salary.html
8楼CXXSoft昨天 20:43
确实不错。尽管工作多年,还是受益匪浅。n关注...
7楼Wentasy昨天 19:35
强烈支持!很多观点深有体会!
6楼caosiyuan1991昨天 19:35
是啊,向楼主致敬!n我现在大三了!n一向以为之前做过项目(大一到大二做过一个餐饮网站,做过一个小的软件,做过一些系统);感觉自己很了不起,现在我算是想明白了,其实我们那个时候的都是基础,我把基础给落下了!n我觉得我要把自己放低点,将基础打牢!
5楼wangqiuyun昨天 19:15
顶起!
4楼aofengdaxia昨天 16:35
事实上我不完全认同你的说法,很多计算机毕业的学生并不能有效的走上对口的岗位,导致计算机行业失业率最高。最主要的原因在于:同学们在学校盲目学习基础知识,不明白这些知识的作用和意义,以及为什么要学习这些知识导致的。无论是C#还是VB或者delphi.都能给人以光明和希望,能看到自己做的东西。反而有助于学生的学习,自下而上的学习,或者自上而下的学习都是可以的,但是我认为自上而下的学习更加有助于学习。n我是一个非计算机系毕业的,现在在软件开发和架构的岗位上做了有一段时间了,我开始学习的asp,后来.net,再后来我就是想搞明白为什么C#运行的原理客服C#的缺点,我学习了C++,学完C++,为了更好的Windows编程,我研究了操作系统原理,接着学习了汇编,在一次开发中,需要自己去做一些脚本,然后学习了编译原理,写着很糟糕的代码,复用很低耦合很高,然后学习了软件工程和面向对象,每次遇到问题,我就去寻找答案,反而不见得很多从底层一头雾水的学习人能明白底层的重要性,如果连为什么要学都不明白,那么一定不能学习好,当然,书呆子可以做到的。
Re: JustJavaC昨天 17:05
回复aofengdaxian可以编程,拖控件,或者做几个小程序的人太多了(俗称“鼠标编程”)。如果基础不牢,你所能做到的,别人也能做到。我觉得升薪的关键在于『你可以做别人做不了的事儿』。nn当然了,你比别人做的快也行(这就是工作经验的结果),别人做完用一个小时,你用半个小时就做完了。那么你就算是codeing行业的熟练工,薪水也比新手高。你在使用工具,你薪水高,是因为你工具使用的熟练。你不是在使用技术。
Re: aofengdaxia昨天 18:49
回复JustJavaCn对于你文中计算机学生应该注重基础知识的观点,表示十分认同,不过方式上可以,而且应该有所变化,我现在带的学生实践,一定让他自己知道为什么学习这个知识,因为我发现他们一但知道为什么学习,就会很好的去学习
Re: JustJavaC昨天 18:58
回复aofengdaxian同意你的观点。『学历代表过去,能力代表现在,学习能力代表未来』,aofengdaxia你的学习能力很强。我还是觉得在学校期间,多多把基础打牢。
3楼qinxiaoqiang2011昨天 15:34
受益匪浅
2楼hiydhiv521昨天 14:02
说的太好了,,顶顶顶
1楼carr123昨天 13:58
"IT业最底层的人是程序员" ???nn你解释一下微软 70 岁的windows大牛还在coding