数学建模社区-数学中国

标题: [转帖]成为优秀程序员的三十条规则 [打印本页]

作者: solucky    时间: 2004-8-26 13:41
标题: [转帖]成为优秀程序员的三十条规则
1)学习应该从基础打起,不要一开始就尝试最高深的技术。
& y$ n* t6 q( r: k* x, H8 i; O1 D* K$ `# q; u/ ?
  2)每看一本书,不要说这章我以前学习过了,也掌握的很好,因此我可以跳过这一章看 更重要的了。
( ~6 i' ]0 ~' G1 a, a; o- ^
3 Z% K7 S2 H8 M9 p( D, X2 d  3)对于作业,遇到不会的尽量不要立刻向别人请教。如果实在解决不了的问题,可以先完成你会的,然后把一些特别的难点提炼出来,向高手请教。
* ]+ m* \7 ?5 m7 {: Y4 ]' [" x, I6 W
  3)不要指望书本和行家能帮你解决一切问题,因为并不是所有问题都能由别人教给你。
6 n+ l- [+ D, ?; L8 [* u$ D. n, b6 Q3 A8 C3 e
  4)向别人请教问题应该把问题说明白。对于错误提示信息应该原样提供出来,不要按自己理解的信息提供。因为既然你自己做不了,说明你理解一般都有问题。   |4 }0 {* |# e' `' P$ K( q
, z1 n% {, p9 _) k
  5)问问题最好能带代码。
0 d+ Z' @7 h7 s" }: i. x% E* N* ]0 |9 b) L" ?6 ^+ k- \/ U
  6)不要说“编译通过,可是运行时...",因为编译错误和运行错误可能根本没有关系。 一般来说,编译是语法问题,而运行是逻辑问题。 / m7 `8 X. f' K) R* i/ l
. \2 ?- q' \2 w3 `5 ~7 s7 v7 {
  7) 书看千遍不如做程序一遍,应该尽量尝试去写程序。 , o( a& N5 F* O2 T/ v- t; g( N
3 t! q- @8 w7 O5 X# w; q8 j+ j
  8)做程序千个不如做好程序一个。应该尽量完善你现在做的程序,而不要不断开新的计 划,而每个计划都虎头蛇尾。   u( h1 k# i- W8 j, B+ Z
  Z" Z1 M/ R  E0 f8 ]
  9)要想到你不是一个人写程序,而是和大家一起写程序。 % X' N2 G6 M. i4 m6 d6 W
; ^5 r* K9 ?) @
  10)高深的技巧虽然显示了高深的本领,但是对于合作往往是有害的,应该尽量写出简 单易读的代码。
7 j6 a1 [, f) e- A0 e' {& a
% p- a; p  X* M. m5 J2 V  11)编制程序应该尽量做到自注释,即代码本身一读就懂,好象自己在说明自己的逻辑一样。
3 G. F9 O+ A0 R9 O8 m( y
" M. ^  \: q: x4 x& F  12)复杂的代码如果实在做不到自注释,应该给出适量的注释。 . |. {6 M) M3 g2 H$ v1 y" O8 g

6 G/ d" ?8 C! u, X( ?; A! @  13)注释在修改代码的时候应该相应修改,不能用陈旧的注释去误导别人。 " _3 }! P2 C$ y6 B3 ]7 `

" D) N! }$ m; j5 w5 C9 w  14)代码应该尽量可重用,相同功能的代码应该由相同的函数完成,重要函数应该给出调试信息,以便调试时及早发现问题。 * Q* _* ?) ~7 g; A# c1 N

' l; S% Q9 }5 ~5 @5 }" t7 }  15)应该尽量写小函数,每个函数尽量不要超过40行或者更少。这样不用滚动屏幕也许就可以读完整个函数。 2 h" h% i9 E! z. k7 A- V

0 ?' a: i$ X$ _; I  16)对于switch语句,尽量不要有过多的分支,如果分支太多,可以考虑用跳转表。 . i" z0 i! x# j4 d' J+ m7 r" ~0 d
8 i( S0 u/ V( P9 K) ^
  17)尽量少使用一些有争议的语句,如goto和三目运算符,既然有争议,它肯定有一定的缺点。
5 n* c# {" S) W
* h( T6 g: e& R2 |  18)对于goto,许多工程师技术高到可以合理使用,而不至于导致问题。但是你的程序并不一定给你同水平的人看和修改,他们可不能保证合理的读和修改这些相关代码。 , R( u' t/ }0 z  q8 e5 ]/ q! j: ^

0 a8 u* u7 T7 I0 {# t0 G( N  19)代码编写时应该有一定的格式,其基本要求是对理解代码有一定帮助。
2 k' T1 R8 o/ W" i8 X; s
7 @0 R+ l1 V& V3 E9 ]; s0 g  20)如果数据是多个模块共有的,应该提供一个封装的类来管理它,并提供一个合适的接口给各个模块。这样,如果数据内容有重大修改,则只要接口不变,基本上可以保证程序不要很复杂的修改。 . O! F1 ~# |8 h- a) I8 m

8 }  s8 Q' `! z  |  21)应该尽量考虑到数据的并发控制。
! Z  l: P0 P$ @" o& h7 }7 X2 I- u+ K/ J+ n' M# Q4 s9 a
  22)数据的并发控制应该封装在接口内,而不要暴露给其他模块,这样可以减少因为并发原因导致的程序死锁。
8 x( I3 d/ J4 Z) A% ~! l
' o/ Z' w& q4 \- L5 y6 P( r  23)数据本身结构不可以太复杂。应该尽量把不相关的数据分割成为两组数据。 ( [" ^: C3 H! M2 N! z/ R0 q+ i

/ X, [& C7 Y" W9 c: @  24)对于数据量比较大的情况,应该考虑数据库。 ' [& p% B- E( `  I3 w. y

, L/ U" v1 g" K0 u4 T  25)数据库接口应该采用标准ODBC或者ADO接口,尽量不要根据实际数据库DBMS提供的接口来处理,因为你可能在实际使用中更换DBMS。
" M$ J. I7 l0 h
' J  w/ w& Y- p8 @* C* E6 `6 p9 ]  26)小的数据可以考虑文件,文件路径应该必须设计成相对路径。
" _$ y2 t8 @6 S& S! e0 X! V1 @2 h8 [
  27)在一个函数中,应该尽量打开文件后使用完后立刻关闭,这样其他程序可能使用文件。 - Z7 {1 a& K* z3 u3 e4 B

2 Z% Q$ p9 U% R1 w% U0 m  28)不要尝试把文件全部读到内存中,应该分次处理大文件。
7 p' j$ C9 E# c& V# f; ^3 W4 h4 h; x- f- I8 i! p5 m  s
  29)编写程序应该提供相关的测试程序,以提供测试手段。 * Y3 F. v, `  R5 B. s; {5 F
/ P! ?3 p4 |0 D" k
  30)应该考虑代码、函数的使用情况,不要超越函数可以使用的范围使用之。
作者: fish133    时间: 2008-11-29 18:30
标题: 看这帖子,我不得不回啊。晕~
看这帖子,我不得不回啊。晕~
作者: wangleiyushulun    时间: 2009-11-12 13:16
学到了一些,呵呵,. a0 I( Q2 v+ k- m) m5 e

作者: legan    时间: 2010-2-1 13:28
这个没有什么新意的的,‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’
作者: lirunhiu    时间: 2010-4-2 23:43
这个没有什么新意的的,‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’‘’
作者: kuang17    时间: 2010-4-11 00:40
耿老师说的一样∑··························
作者: silecainengai    时间: 2010-4-13 12:22
顶一下。。。。。。。。。。。。。。。。。。。。。
作者: jingxingde    时间: 2010-6-8 19:34
顶一下。。。。。。。。。。。。。。。。。。。。。
8 X# e; b- q2 q! Y* e+ B0 u
作者: duan3307464    时间: 2010-8-9 20:45
每个编程人员多少都可以总结一些,但对于新手会有所帮助
作者: duan3307464    时间: 2010-8-9 21:02
每个编程人员多少都可以总结一些,但对于新手会有所帮助
作者: GraBUAA    时间: 2012-3-18 10:29
很不错,谢谢分享
作者: yingxiaowang    时间: 2012-7-27 23:21
还是要坚持吧。。。因为学习方法对每个然的都是不一样的。。,
作者: feng67    时间: 2012-10-26 09:37
   




欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5