- 在线时间
- 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)学习应该从基础打起,不要一开始就尝试最高深的技术。
* O) [: |. P3 \2 {
* p' C/ \/ w# g5 J1 |' Z y6 O 2)每看一本书,不要说这章我以前学习过了,也掌握的很好,因此我可以跳过这一章看 更重要的了。
" D* Z- l( S7 Q- w1 M
8 n: ^. V% p& H2 l% Q6 E' X/ |( T 3)对于作业,遇到不会的尽量不要立刻向别人请教。如果实在解决不了的问题,可以先完成你会的,然后把一些特别的难点提炼出来,向高手请教。 . U% w2 N# G0 {. s
( @$ U* w4 T2 r- q 3)不要指望书本和行家能帮你解决一切问题,因为并不是所有问题都能由别人教给你。 4 G0 V4 \8 l$ w% [
' R3 c3 E+ u0 X/ s2 C) G0 j 4)向别人请教问题应该把问题说明白。对于错误提示信息应该原样提供出来,不要按自己理解的信息提供。因为既然你自己做不了,说明你理解一般都有问题。 ; Y: N% {' W: k& v* n
$ `6 U# H. w/ E: M1 o
5)问问题最好能带代码。 " k4 Z8 p: S6 Y3 }# \( w
& N" V& Y# f9 v1 v9 ~4 c
6)不要说“编译通过,可是运行时...",因为编译错误和运行错误可能根本没有关系。 一般来说,编译是语法问题,而运行是逻辑问题。 3 R$ O% I/ V' ~& |( |
" M7 t# D) R* Y! \$ S7 f I
7) 书看千遍不如做程序一遍,应该尽量尝试去写程序。 ! Q; K$ Y2 E m$ ~
/ O7 W3 [' g0 C. }, ? w- q1 z$ B
8)做程序千个不如做好程序一个。应该尽量完善你现在做的程序,而不要不断开新的计 划,而每个计划都虎头蛇尾。 2 d8 a$ W6 @. g7 `( u: w+ r
; [3 W' x: J Z2 b; _
9)要想到你不是一个人写程序,而是和大家一起写程序。 + ]" J, u3 ^# V, t
2 m" K' \0 m0 e) p! m! H. U 10)高深的技巧虽然显示了高深的本领,但是对于合作往往是有害的,应该尽量写出简 单易读的代码。
4 ]. E5 `1 }$ E* [
. x' ~/ q* S" d4 u9 x 11)编制程序应该尽量做到自注释,即代码本身一读就懂,好象自己在说明自己的逻辑一样。 : z0 r( h- U7 c4 O
/ k4 j5 U8 r8 ^* e9 G 12)复杂的代码如果实在做不到自注释,应该给出适量的注释。
2 z5 z+ X7 v; P4 |) m2 @6 `* |- D5 m% J5 i7 v; g- g
13)注释在修改代码的时候应该相应修改,不能用陈旧的注释去误导别人。
+ R7 e3 A3 Z1 `8 _6 g* N0 l6 S2 x' y8 D
14)代码应该尽量可重用,相同功能的代码应该由相同的函数完成,重要函数应该给出调试信息,以便调试时及早发现问题。
5 v: ?) O' s# C& r# `0 W( W& S2 e/ \' o9 p
15)应该尽量写小函数,每个函数尽量不要超过40行或者更少。这样不用滚动屏幕也许就可以读完整个函数。
2 @4 }! F* c- p1 ^
& a2 O$ {1 p. g y) ]8 i 16)对于switch语句,尽量不要有过多的分支,如果分支太多,可以考虑用跳转表。
u0 f/ K, Z9 t; `: `% r6 o. m- W% c/ s7 o% d1 f3 b
17)尽量少使用一些有争议的语句,如goto和三目运算符,既然有争议,它肯定有一定的缺点。 3 k& [% \$ e# V9 r' z7 u
/ L) R7 _5 H/ ]$ I# J5 Z7 c
18)对于goto,许多工程师技术高到可以合理使用,而不至于导致问题。但是你的程序并不一定给你同水平的人看和修改,他们可不能保证合理的读和修改这些相关代码。
' [' C e! _5 E, s \9 i3 g% O# G" [: ^. {5 {
19)代码编写时应该有一定的格式,其基本要求是对理解代码有一定帮助。
# Y2 y, \: a: d
& |" \/ h C* X7 O/ e 20)如果数据是多个模块共有的,应该提供一个封装的类来管理它,并提供一个合适的接口给各个模块。这样,如果数据内容有重大修改,则只要接口不变,基本上可以保证程序不要很复杂的修改。 5 W! u/ }# F* C; A5 o" e% f! G
9 F; X0 L3 n" e | 21)应该尽量考虑到数据的并发控制。 ) H5 x3 F1 T6 T; d
. w2 [/ S% k5 r' Y
22)数据的并发控制应该封装在接口内,而不要暴露给其他模块,这样可以减少因为并发原因导致的程序死锁。 5 q5 c: [5 o6 m, q+ Y5 K
. r9 ~6 e1 |- p# h1 w$ A4 Q$ c 23)数据本身结构不可以太复杂。应该尽量把不相关的数据分割成为两组数据。
6 q% _) J/ B0 w9 `5 C
3 K y9 `. ~3 m% i; |- p 24)对于数据量比较大的情况,应该考虑数据库。 : _6 v6 {7 J+ g2 q+ X0 p
. n) x1 V8 c- W" o$ \+ Q5 y
25)数据库接口应该采用标准ODBC或者ADO接口,尽量不要根据实际数据库DBMS提供的接口来处理,因为你可能在实际使用中更换DBMS。 $ H0 _: k3 O+ p8 A2 {- F
# p7 u8 k6 c8 B 26)小的数据可以考虑文件,文件路径应该必须设计成相对路径。 8 N- f2 R: U8 x0 |8 S, N8 }
! U! t+ z# G! D7 ~3 O2 b
27)在一个函数中,应该尽量打开文件后使用完后立刻关闭,这样其他程序可能使用文件。 - |" b: O: y: H _ l2 d
' T9 N, b* B% F& u 28)不要尝试把文件全部读到内存中,应该分次处理大文件。
3 M7 J* y V6 f
" j: `# @% o' H( z 29)编写程序应该提供相关的测试程序,以提供测试手段。
3 ?; K6 X; j0 W9 K* v. B
+ v0 p+ q9 o5 I* d% [$ e& a6 J3 ^ 30)应该考虑代码、函数的使用情况,不要超越函数可以使用的范围使用之。 |
zan
|