- 在线时间
- 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)学习应该从基础打起,不要一开始就尝试最高深的技术。 + m6 v. J P2 Q# D
. k! Y0 U7 g9 ]7 w" I( w$ I
2)每看一本书,不要说这章我以前学习过了,也掌握的很好,因此我可以跳过这一章看 更重要的了。 6 S' s- p& J) j! F' U P
) B, n' R/ j- A8 }* i1 J. J 3)对于作业,遇到不会的尽量不要立刻向别人请教。如果实在解决不了的问题,可以先完成你会的,然后把一些特别的难点提炼出来,向高手请教。 1 T3 j: E" o) [+ w! ~/ i
- q; v8 \6 X/ E$ m' s; W# I$ J 3)不要指望书本和行家能帮你解决一切问题,因为并不是所有问题都能由别人教给你。
0 d5 L* J0 ?' K+ X- T
( ^/ A. ? l. U9 c: }9 E 4)向别人请教问题应该把问题说明白。对于错误提示信息应该原样提供出来,不要按自己理解的信息提供。因为既然你自己做不了,说明你理解一般都有问题。
: u$ m N) M) H# Y$ a; O/ l C# x" S9 s4 D! g
5)问问题最好能带代码。
* K3 F/ N4 T9 M4 h# R- D2 V5 l+ }% E5 r4 r! q
6)不要说“编译通过,可是运行时...",因为编译错误和运行错误可能根本没有关系。 一般来说,编译是语法问题,而运行是逻辑问题。 / K$ Y) k4 X+ [, i
\7 l% z1 T4 d7 G 7) 书看千遍不如做程序一遍,应该尽量尝试去写程序。 7 R4 T" I, ?: I! w
& K8 b9 ? m$ @% Y( Z
8)做程序千个不如做好程序一个。应该尽量完善你现在做的程序,而不要不断开新的计 划,而每个计划都虎头蛇尾。 ; \* g0 f! i. A9 Z8 `
1 r/ Y5 q3 k1 b 9)要想到你不是一个人写程序,而是和大家一起写程序。 # X7 `1 u( c+ g8 ?# c; Q
0 k# G% b5 I' o; x
10)高深的技巧虽然显示了高深的本领,但是对于合作往往是有害的,应该尽量写出简 单易读的代码。
/ E( G6 x7 ~2 ^1 j+ U: Y# N# B1 H1 x4 ?1 b( L( D2 }7 |
11)编制程序应该尽量做到自注释,即代码本身一读就懂,好象自己在说明自己的逻辑一样。 $ K& s6 u: J5 J4 a
6 \$ O; l. ?2 N5 e, [7 ~
12)复杂的代码如果实在做不到自注释,应该给出适量的注释。
- N2 O, J7 j# |8 j W
: f L5 h7 Q/ a: J1 X 13)注释在修改代码的时候应该相应修改,不能用陈旧的注释去误导别人。 " \+ P; R& R3 |; l$ n7 a
( @: Z$ T9 ?! e/ L: A5 Y 14)代码应该尽量可重用,相同功能的代码应该由相同的函数完成,重要函数应该给出调试信息,以便调试时及早发现问题。 / y9 |) l9 p! F& N6 j$ u
* `$ s9 a5 y, n; _
15)应该尽量写小函数,每个函数尽量不要超过40行或者更少。这样不用滚动屏幕也许就可以读完整个函数。
5 M% B& `, ?: S, T! u3 H' q m- c; H
16)对于switch语句,尽量不要有过多的分支,如果分支太多,可以考虑用跳转表。
9 h5 S1 R3 d" s5 o. Z4 z3 _% K2 {' a1 l0 o# j, Z
17)尽量少使用一些有争议的语句,如goto和三目运算符,既然有争议,它肯定有一定的缺点。 , ?: s& W6 {/ g. Q; F8 p
( }. o9 \% P: y+ O; N" U 18)对于goto,许多工程师技术高到可以合理使用,而不至于导致问题。但是你的程序并不一定给你同水平的人看和修改,他们可不能保证合理的读和修改这些相关代码。
( Q5 k$ E3 n. D Z7 V+ F; ]1 ?' X, R" R) F( _7 @. h+ [
19)代码编写时应该有一定的格式,其基本要求是对理解代码有一定帮助。
% B( J" ^: Q" A" r# d1 @, V: B3 J1 P
20)如果数据是多个模块共有的,应该提供一个封装的类来管理它,并提供一个合适的接口给各个模块。这样,如果数据内容有重大修改,则只要接口不变,基本上可以保证程序不要很复杂的修改。 7 V; ^( v' W( N
X; w4 Y( r0 N
21)应该尽量考虑到数据的并发控制。
+ u) e# R' d- ?9 a! \% S' B0 A. E& }' R+ \+ ^4 \3 U
22)数据的并发控制应该封装在接口内,而不要暴露给其他模块,这样可以减少因为并发原因导致的程序死锁。 Z+ w+ g7 E6 t. f; F3 c$ @
6 w: l% d' l; k: e! M' h
23)数据本身结构不可以太复杂。应该尽量把不相关的数据分割成为两组数据。
! D6 ^; ? J0 j$ m2 N1 |/ b/ ^4 e2 I& v l# e6 C/ w
24)对于数据量比较大的情况,应该考虑数据库。 4 }) P. H. u; u& J5 a) c
5 Z$ ^- \ X7 R2 S
25)数据库接口应该采用标准ODBC或者ADO接口,尽量不要根据实际数据库DBMS提供的接口来处理,因为你可能在实际使用中更换DBMS。 + p! p5 c, {4 R
! J# S5 q# _+ A3 A3 p0 k4 d) o m 26)小的数据可以考虑文件,文件路径应该必须设计成相对路径。 8 M* r4 G$ w" U, e+ k6 N
% W' \9 r# f7 u9 c
27)在一个函数中,应该尽量打开文件后使用完后立刻关闭,这样其他程序可能使用文件。 # ?! D5 C: }+ {" m
4 h+ i, S5 ~/ E8 e6 Y* p1 Q% X
28)不要尝试把文件全部读到内存中,应该分次处理大文件。
4 Y z' u o1 U+ s
, D; s/ g) v; A! { 29)编写程序应该提供相关的测试程序,以提供测试手段。
. k5 |0 Y- k9 f P6 }1 ]& R
. i8 h* n# N8 E# m! _$ D8 @ 30)应该考虑代码、函数的使用情况,不要超越函数可以使用的范围使用之。 |
zan
|