- 在线时间
- 0 小时
- 最后登录
- 2006-3-12
- 注册时间
- 2004-5-30
- 听众数
- 1
- 收听数
- 0
- 能力
- 0 分
- 体力
- 262 点
- 威望
- 0 点
- 阅读权限
- 30
- 积分
- 109
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 27
- 主题
- 17
- 精华
- 1
- 分享
- 0
- 好友
- 0
升级   4.5% 该用户从未签到
 |
1)学习应该从基础打起,不要一开始就尝试最高深的技术。 9 z" x' c! L9 N6 L" |5 @
+ k" V( v3 e2 ]8 K* L, ^3 E
2)每看一本书,不要说这章我以前学习过了,也掌握的很好,因此我可以跳过这一章看 更重要的了。
! w$ t) `' G% ]2 C* E" Q7 \6 Y( x e+ p8 c
3)对于作业,遇到不会的尽量不要立刻向别人请教。如果实在解决不了的问题,可以先完成你会的,然后把一些特别的难点提炼出来,向高手请教。
! m7 r$ L5 N4 w& C$ N' [, w* Q
1 h! P* h+ H: {. _/ _3 M 3)不要指望书本和行家能帮你解决一切问题,因为并不是所有问题都能由别人教给你。
; |/ S2 X# t7 L$ ?# o, H @/ o! h9 b J0 r7 m- X
4)向别人请教问题应该把问题说明白。对于错误提示信息应该原样提供出来,不要按自己理解的信息提供。因为既然你自己做不了,说明你理解一般都有问题。
& @/ {3 |2 }$ B. ~; v( S1 t- B. |, S; i/ O# {
5)问问题最好能带代码。
( a3 x4 G3 T' x; V9 `& @+ L& S' o
& ]! {/ N) N: r' ` 6)不要说“编译通过,可是运行时...",因为编译错误和运行错误可能根本没有关系。 一般来说,编译是语法问题,而运行是逻辑问题。 1 c2 V1 j+ J" q O0 W9 z, O( m& v& \* q: Z
8 c. o/ Y8 X, ?9 |/ T
7) 书看千遍不如做程序一遍,应该尽量尝试去写程序。
/ Y" i: I5 m, ~) X8 Z5 a* f$ R) ?9 V+ ?
8)做程序千个不如做好程序一个。应该尽量完善你现在做的程序,而不要不断开新的计 划,而每个计划都虎头蛇尾。 ) @5 i: V) M/ h l1 |
' m! h5 _) R$ s$ e6 U6 @
9)要想到你不是一个人写程序,而是和大家一起写程序。 ; d. i$ ?+ x$ {- S. ~
" j* z% M6 U T" [' u8 t9 ~
10)高深的技巧虽然显示了高深的本领,但是对于合作往往是有害的,应该尽量写出简 单易读的代码。
* y: n2 X5 Z7 b* Y: C p. X, B/ P. Z. x- \) q0 k
11)编制程序应该尽量做到自注释,即代码本身一读就懂,好象自己在说明自己的逻辑一样。 5 j' g: P5 |- [- z9 t0 b' H
2 V- f2 p% [6 q 12)复杂的代码如果实在做不到自注释,应该给出适量的注释。 0 u3 d! D9 H2 k: F [ H
9 u8 b: T$ X6 K* X* {+ {: n& I
13)注释在修改代码的时候应该相应修改,不能用陈旧的注释去误导别人。
L6 M: H1 I7 R" W* x; A5 ^% r' n# D3 o. g2 }- l) K
14)代码应该尽量可重用,相同功能的代码应该由相同的函数完成,重要函数应该给出调试信息,以便调试时及早发现问题。
. m$ Z0 ~1 F) F( s: t0 ^1 a8 _% ?1 I) y& o1 C3 u2 p$ E6 S9 C
15)应该尽量写小函数,每个函数尽量不要超过40行或者更少。这样不用滚动屏幕也许就可以读完整个函数。
4 d, k. ^6 D0 Z3 }1 C% Z8 V0 e3 ~3 e3 b0 S5 j; p
16)对于switch语句,尽量不要有过多的分支,如果分支太多,可以考虑用跳转表。 - j4 U: c7 Q; `/ `' Q
8 x: U* m9 I' E4 H' J% S
17)尽量少使用一些有争议的语句,如goto和三目运算符,既然有争议,它肯定有一定的缺点。
5 l6 L) B- q% e, N+ r& t5 Z, v7 d* C; b0 Q3 {' _1 G7 {2 w' o1 F# g
18)对于goto,许多工程师技术高到可以合理使用,而不至于导致问题。但是你的程序并不一定给你同水平的人看和修改,他们可不能保证合理的读和修改这些相关代码。 3 l4 c {" }& e L1 P; m
5 ^% w$ |* e. P. i- J9 e 19)代码编写时应该有一定的格式,其基本要求是对理解代码有一定帮助。 ! P2 v+ w7 l; r: H1 O8 k
" w4 s0 ?. n9 R- o 20)如果数据是多个模块共有的,应该提供一个封装的类来管理它,并提供一个合适的接口给各个模块。这样,如果数据内容有重大修改,则只要接口不变,基本上可以保证程序不要很复杂的修改。 ' j: B6 c+ C- h+ Z
6 o2 G* O j( ]! k2 W& J O
21)应该尽量考虑到数据的并发控制。 " S5 {# d* X# m, g! N& I
& P# Z4 S5 C1 g d 22)数据的并发控制应该封装在接口内,而不要暴露给其他模块,这样可以减少因为并发原因导致的程序死锁。 1 G7 `$ |! {9 b) U5 W2 o! Q- B+ b
# ?- B) L8 q0 K4 Z/ A# y. G 23)数据本身结构不可以太复杂。应该尽量把不相关的数据分割成为两组数据。
& ?0 s6 L: d" X9 t v& m+ f( t. Q+ b7 D- U4 D
24)对于数据量比较大的情况,应该考虑数据库。
# J& }4 z( P3 n; I% }* W3 K4 \( ], t3 _% N# S/ g+ }+ v" x
25)数据库接口应该采用标准ODBC或者ADO接口,尽量不要根据实际数据库DBMS提供的接口来处理,因为你可能在实际使用中更换DBMS。 9 E8 z0 V. e/ X+ m
# @6 y* T. o, I) g" Y0 A& e( O u
26)小的数据可以考虑文件,文件路径应该必须设计成相对路径。 . G' P6 P3 j/ v7 u* ?
: I1 P) Q; N6 v! p. I' G2 ~3 I 27)在一个函数中,应该尽量打开文件后使用完后立刻关闭,这样其他程序可能使用文件。
* |) c% g2 p) s, N
# L, t; n8 e% f9 ? 28)不要尝试把文件全部读到内存中,应该分次处理大文件。
5 Q: I% A2 c$ ^" P
& x7 O9 l5 l i: u" D& F0 g 29)编写程序应该提供相关的测试程序,以提供测试手段。 9 [+ e4 |: m, ~2 X7 [ k+ |
/ ?2 B2 Z/ d/ Z0 ^( R 30)应该考虑代码、函数的使用情况,不要超越函数可以使用的范围使用之。 |
zan
|