1)学习应该从基础打起,不要一开始就尝试最高深的技术。 , _ Z m# k i8 V- P# g+ q5 A* a8 \7 `$ r
2)每看一本书,不要说这章我以前学习过了,也掌握的很好,因此我可以跳过这一章看 更重要的了。 ! e; l, t. ^8 a+ `
1 z. T l* m$ G) p
3)对于作业,遇到不会的尽量不要立刻向别人请教。如果实在解决不了的问题,可以先完成你会的,然后把一些特别的难点提炼出来,向高手请教。 : @ P" x+ V6 T9 q, j* v
8 F, d) Q* E2 U' f8 i# ?! ]7 y# Q, q
3)不要指望书本和行家能帮你解决一切问题,因为并不是所有问题都能由别人教给你。 1 x$ P! x3 I" w/ x' P P6 F
$ P( K2 E: s1 l5 J) J
4)向别人请教问题应该把问题说明白。对于错误提示信息应该原样提供出来,不要按自己理解的信息提供。因为既然你自己做不了,说明你理解一般都有问题。 % H$ {( |" P. K 1 Y9 Y1 k* b: J2 F 5)问问题最好能带代码。 / p$ c o8 @6 `) _8 B; k5 h / W5 H9 R: d) r# p 6)不要说“编译通过,可是运行时...",因为编译错误和运行错误可能根本没有关系。 一般来说,编译是语法问题,而运行是逻辑问题。 . S* r3 h$ W8 l# H, y7 i; K" {4 [- j
7) 书看千遍不如做程序一遍,应该尽量尝试去写程序。 6 ~; g2 O% z# G5 s) B
' E+ y# t1 U; a+ {
8)做程序千个不如做好程序一个。应该尽量完善你现在做的程序,而不要不断开新的计 划,而每个计划都虎头蛇尾。 ! a* W1 p# t' N# Q$ L : W6 Q( T. r' A. ` 9)要想到你不是一个人写程序,而是和大家一起写程序。 ! u% o% i7 Z) U+ c( o; C 5 E& i) m8 Z- ?; `* \; f, c 10)高深的技巧虽然显示了高深的本领,但是对于合作往往是有害的,应该尽量写出简 单易读的代码。 $ b+ o2 ]( r5 G: J$ n1 z) q8 g5 q0 K# G$ c
11)编制程序应该尽量做到自注释,即代码本身一读就懂,好象自己在说明自己的逻辑一样。 ' E+ c* k2 O; F5 v5 B5 u
0 \8 I0 x& q5 L9 g) ~ 12)复杂的代码如果实在做不到自注释,应该给出适量的注释。 ; k% i" e, ]2 [( C8 | M) g7 A3 u( n. ?* y+ b
13)注释在修改代码的时候应该相应修改,不能用陈旧的注释去误导别人。 , x+ t! } b) F' v: X
! U+ X6 a& E) h9 h% W) z; z 14)代码应该尽量可重用,相同功能的代码应该由相同的函数完成,重要函数应该给出调试信息,以便调试时及早发现问题。 & N3 q+ P. v, _* Z+ o' ?% ^2 k
* ]) z# c5 {3 L5 z; M 15)应该尽量写小函数,每个函数尽量不要超过40行或者更少。这样不用滚动屏幕也许就可以读完整个函数。 * P& ?, w. s9 V& e" m d! G- h 4 s- C- Y+ m5 x 16)对于switch语句,尽量不要有过多的分支,如果分支太多,可以考虑用跳转表。 ; V- i% F' I2 E& M8 d3 c2 U @. }/ C; o5 Q' C" F$ g' J* n' d& T
17)尽量少使用一些有争议的语句,如goto和三目运算符,既然有争议,它肯定有一定的缺点。 - k, G/ g2 M: Y8 s/ Z& V
7 k( [4 K. `) K, _4 c0 ?
18)对于goto,许多工程师技术高到可以合理使用,而不至于导致问题。但是你的程序并不一定给你同水平的人看和修改,他们可不能保证合理的读和修改这些相关代码。 % ?$ g- M* i( l& Y. H ( d: e: M8 x9 ^% L) O, I 19)代码编写时应该有一定的格式,其基本要求是对理解代码有一定帮助。 2 j4 f3 v4 a. r% [6 ?: I% W" V
' u( J1 C S" X+ v" |9 B3 N6 m 20)如果数据是多个模块共有的,应该提供一个封装的类来管理它,并提供一个合适的接口给各个模块。这样,如果数据内容有重大修改,则只要接口不变,基本上可以保证程序不要很复杂的修改。 8 K! {2 O$ a% O/ I0 D' }" q
8 F( G v' F l% U& i. {/ [8 W7 H l! w 21)应该尽量考虑到数据的并发控制。 2 O4 A* u% L8 U+ A, `
4 k+ T- W" C* p& p0 d 22)数据的并发控制应该封装在接口内,而不要暴露给其他模块,这样可以减少因为并发原因导致的程序死锁。 8 C! J! u. `* k6 s% M
/ m4 W9 D( Q4 R7 R* f 23)数据本身结构不可以太复杂。应该尽量把不相关的数据分割成为两组数据。 . o* V+ M* S' ?; k ; _" w) F1 ?9 i: `8 X 24)对于数据量比较大的情况,应该考虑数据库。 $ }& v7 m3 q0 g0 ^6 w$ k
% ?! {6 n* ^% P' M- i6 h+ O 25)数据库接口应该采用标准ODBC或者ADO接口,尽量不要根据实际数据库DBMS提供的接口来处理,因为你可能在实际使用中更换DBMS。 # B% T* ^" }( Z5 S% Q. N7 r( g : B( c3 w$ E& b) w! w8 { 26)小的数据可以考虑文件,文件路径应该必须设计成相对路径。 : v5 N& Z) I1 H4 Z( b+ o