如何成为一个好的程序员

lyj437727815 2011-07-30 11:30:25
程序员不只是会编写程序,更要具备有hack(不是黑客)的能力,去用最优的方法去解决问题。要有hack的精神(大家要把它和crack分清),一种探索的能力,一种创新的能力,这样才能算得上优秀。

1)学习应该从基础打起,不要一开始就尝试最高深的技术。 &seq
2)每看一本书,不要说这章我以前学习过了,也掌握的很好,因此我可以跳过这一章看更重要的了。2g
3)对于作业,遇到不会的尽量不要立刻向别人请教。如果实在解决不了的问题,可以先完成你会的,然后把一些特别的难点提炼出来,向高手请教。fk
3)不要指望书本和行家能帮你解决一切问题,因为并不是所有问题都能由别人教给你。 -
4)向别人请教问题应该把问题说明白。对于错误提示信息应该原样提供出来,不要按自己理解的信息提供。因为既然你自己做不了,说明你理解一般都有问题。ED
5)问问题最好能带代码。IyB7U*
6)不要说“编译通过,可是运行时...",因为编译错误和运行错误可能根本没有关系。一般来说,编译是语法问题,而运行是逻辑问题。tM>o
7) 书看千遍不如做程序一遍,应该尽量尝试去写程序。^]-[_
8)做程序千个不如做好程序一个。应该尽量完善你现在做的程序,而不要不断开新的计划,而每个计划都虎头蛇尾。eQr8A
9)要想到你不是一个人写程序,而是和大家一起写程序。?5Nq7
10)高深的技巧虽然显示了高深的本领,但是对于合作往往是有害的,应该尽量写出简单易读的代码。DIao>N
11)编制程序应该尽量做到自注释,即代码本身一读就懂,好象自己在说明自己的逻辑一样。fD
12)复杂的代码如果实在做不到自注释,应该给出适量的注释。Z\'7
13)注释在修改代码的时候应该相应修改,不能用陈旧的注释去误导别人。@m+
14)代码应该尽量可重用,相同功能的代码应该由相同的函数完成,重要函数应该给出调试信息,以便调试时及早发现问题。hWDg(.
15)应该尽量写小函数,每个函数尽量不要超过40行或者更少。这样不用滚动屏幕也许就可以读完整个函数。r
16)对于switch语句,尽量不要有过多的分支,如果分支太多,可以考虑用跳转表。x
17)尽量少使用一些有争议的语句,如goto和三目运算符,既然有争议,它肯定有一定的缺点。0%*tn
18)对于goto,许多工程师技术高到可以合理使用,而不至于导致问题。但是你的程序并不一定给你同水平的人看和修改,他们可不能保证合理的读和修改这些相关代码。??X:H
19)代码编写时应该有一定的格式,其基本要求是对理解代码有一定帮助。E
20)如果数据是多个模块共有的,应该提供一个封装的类来管理它,并提供一个合适的接口给各个模块。这样,如果数据内容有重大修改,则只要接口不变,基本上可以保证程序不要很复杂的修改。*SH
21)应该尽量考虑到数据的并发控制。12Lh-
22)数据的并发控制应该封装在接口内,而不要暴露给其他模块,这样可以减少因为并发原因导致的程序死锁。q
23)数据本身结构不可以太复杂。应该尽量把不相关的数据分割成为两组数据。aSFS,
24)对于数据量比较大的情况,应该考虑数据库。}\',
25)数据库接口应该采用标准ODBC或者ADO接口,尽量不要根据实际数据库DBMS提供的接口来处理,因为你可能在实际使用中更换DBMS。&\'dZjI
26)小的数据可以考虑文件,文件路径应该必须设计成相对路径。jo
27)在一个函数中,应该尽量打开文件后使用完后立刻关闭,这样其他程序可能使用文件。WM ,SG
28)不要尝试把文件全部读到内存中,应该分次处理大文件。y9{
29)编写程序应该提供相关的测试程序,以提供测试手段。0,G0!~
30)应该考虑代码、函数的使用情况,不要超越函数可以使用的范围使用之。s~©中国Java实验室(ChinaJavaLab)技术论坛 -- 中国Java实验室技术论坛 HKe
1. 扎实的基础。数据结构、离散数学、编译原理,这些是所有计算机科学的基础,如果不掌握他们,很难写出高水平的程序。据我的观察,学计算机专业的人比学其他专业的人更能写出高质量的软件。程序人人都会写,但当你发现写到一定程度很难再提高的时候,就应该想想是不是要回过头来学学这些最基本的理论。不要一开始就去学OOP,即使你再精通OOP,遇到一些基本算法的时候可能也会束手无策。 |x
2. 丰富的想象力。不要拘泥于固定的思维方式,遇到问题的时候要多想几种解决问题的方案,试试别人从没想过的方法。丰富的想象力是建立在丰富的知识的基础上,除 计算机以外,多涉猎其他的学科,比如天文、物理、数学等等。另外,多看科幻电影也是一个很好的途径。 Um9f
3. 最简单的是最好的。这也许是所有科学都遵循的一条准则,如此复杂的质能互换原理在爱因斯坦眼里不过是一个简单得不能再简单的公式:E=mc2。简单的方法更容易被人理解,更容易实现,也更容易维护。遇到问题时要优先考虑最简单的方案,只有简单方案不能满足要求时再考虑复杂的方案。 E)U,w
4. 不钻牛角尖。当你遇到障碍的时候,不妨暂时远离电脑,看看窗外的风景,听听轻音乐,和朋友聊聊天。当我遇到难题的时候会去玩游戏,而且是那种极暴力的打斗类游戏,当负责游戏的那部分大脑细胞极度亢奋的时候,负责编程的那部分大脑细胞就得到了充分的休息。当重新开始工作的时候,我会发现那些难题现在竟然可以迎刃而解。 DcQ\\k6
5. 对答案的渴求。人类自然科学的发展史就是一个渴求得到答案的过程,即使只能知道答案的一小部分也值得我们去付出。只要你坚定信念,一定要找到问题的答案,你才会付出精力去探索,即使最后没有得到答案,在过程中你也会学到很多东西。 8a]4
6. 多与别人交流。三人行必有我师,也许在一次和别人不经意的谈话中,就可以迸出灵感的火花。多上上网,看看别人对同一问题的看法,会给你很大的启发。 l$
7. 良好的编程风格。注意养成良好的习惯,代码的缩进编排,变量的命名规则要始终保持一致。大家都知道如何排除代码中错误,却往往忽视了对注释的排错。注释是程序的一个重要组成部分,它可以使你的代码更容易理解,而如果代码已经清楚地表达了你的思想,就不必再加注释了,如果注释和代码不一致,那就更加糟糕。 OhCpa
8. 韧性和毅力。这也许是"高手"和一般程序员最大的区别。A good programming OMEVO
is 99 weat and 1ffee。高手们并不是天才,他们是在无数个日日夜夜中磨练出来的G.
。成功能给我们带来无比的喜悦,但过程却是无比的枯燥乏味。你不妨做个测试,找个1wv#7
0000以内的素数表,把它们全都抄下来,然后再检查三遍,如果能够不间断地完成这一T1^z
工作,你就可以满足这一条。 5Dvr©中国Java实验室(ChinaJavaLab)技术论坛 -- 中国Java实验室技术论坛 (v%
* 比较宽的知识面,并且能够时时补充自己的知识和完善自己的知识结构 5
* 耐心好,特别是在调试和学习阶段,世界上没有聪明的人只有刻苦的人。做开发其实就两件事情学习和改错,在这两件事情中间的开发过程其实是比较简单的 \\K2
* 永远记住:代码是给人看的而不是给机器运行的,计算机在执行程序时是不怕累的,而人在看代码时是非常累的 q
* 良好的编码习惯,至少保证自己能够随时看懂几个月前自己所写的代码 P
* 尽量让你的代码能够很容易的被别人理解,写代码时想想你会不会在两个月后被别人骂 HAh
* 不要容忍自己犯重复的错误和写重复的代码 c
* 知道如何做比得到代码更重要 6q``
* 尽量不要做已经有很多人已经做过的事情 h\\kZqt
* 学会尊重别人的开发成果,除非不得已不要下决定全面替换以前的系统 o\\>
* 珍惜自己的时间与工作成果,尽量让别人分享自己的开发成果 b\'0?N
* 避免假设,多思考极端情况与引起错误的可能性,努力减少低级错误 scA}
* 不要相信至少是不要轻信自己为自己所做的测试结果 mq
* 懂得坚持自己的开发思路,并懂得理解与吸收别人的思想 !AW
* 学会与其他人保持一致,但不能放弃自己的开发特色 hq3
* 懂得向你周围的人学习,不论是开发能力上的还是开发经验上的 PF>
* 懂得软件结构的的重要性,分析代码前先分析代码的结构 uGK
* 学会总结,定期总结自己所学会的知识,看看自己前段时间因为各种原因所浪费的时间 )HNUX
* 学会计划,尽量不要认为通过延长自己的工作时间来完成任务 {|k2
* 学会正确估计自己的能力和工作时间 2r2
下面这些是我认为一些比较适合我自己的方面,不一定对每个人都合适: BI8&!
* 多看些杂志,没事情的时候可以看看以前看过的参考书,书中很可能有你以前没有注意到的一些细节 >mti\'
* 不要太早去做一些与开发无关的事情,因为学习的黄金时期是很短暂的 |<AN
* 学会分析别人的系统,多看看别人所开发的系统的先进的一面。这里包括别人的开发思路,实现时所采用的结构 m:B@Mq
* 时常感到自己将被淘汰,经常埋怨自己的不努力 #W
* 知道自己缺少什么 5Ql\'
* 强迫自己做一些自己不喜欢做的事情,比如说写文档 9<v7ro
* 能够有勇气重写自己所开发的系统,但当你重做时你应该采取和前一次不同的工作方式和方法,否则重做就没有必要 y>
* 将问题简单化而不是复杂化 lo8mPY
* 将维护时会产生的一部分问题转移到开发时或是设计时来解决 `Hc
* 有时候也不妨问问自己:我不做开发时去做什么 j`CN
* 坚持为自己做每周的开发计划,在事情没有做完以前不要轻易转移自己的注意力 x
* 尽可能多的将你所做的教给别人,因为你有一天可能不再负责这个系统 6}Q
* 做事一定要有始有终,除非是有不得已的理由否则不要在工作完成前提前离开 si
* 不要将你为公司做的东西带走,你因该带走的是开发经验和对开发的认识而不是代码和产品 >*c{z)
* 感到累时就休息一下,给自己放个假也无妨,毕竟人不是机器 QI{RaS
做程序员很累的,够你受的,加油吧!l
...全文
53 点赞 收藏 回复
写回复
回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
相关推荐
发帖
非技术区
创建于2007-09-28

1056

社区成员

硬件/嵌入开发 非技术区
申请成为版主
帖子事件
创建了帖子
2011-07-30 11:30
社区公告
暂无公告