- 在线时间
- 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)学习应该从基础打起,不要一开始就尝试最高深的技术。 6 y! z7 p+ f" c9 P# W4 W$ T
3 g( M/ ?+ u F8 m8 ]
2)每看一本书,不要说这章我以前学习过了,也掌握的很好,因此我可以跳过这一章看 更重要的了。 " {" I+ V0 K4 S- d/ b' m
$ ] c" @; [( O/ L; m, N
3)对于作业,遇到不会的尽量不要立刻向别人请教。如果实在解决不了的问题,可以先完成你会的,然后把一些特别的难点提炼出来,向高手请教。
7 @ e- P9 @7 v8 d+ T4 f" D/ Z9 V- |
3)不要指望书本和行家能帮你解决一切问题,因为并不是所有问题都能由别人教给你。
. \% x, s) Y# X6 {* Q3 Z$ W! R# w. N3 ^
4)向别人请教问题应该把问题说明白。对于错误提示信息应该原样提供出来,不要按自己理解的信息提供。因为既然你自己做不了,说明你理解一般都有问题。
3 }6 \( \! I' Z" p, b& G4 ]
! d7 M4 e/ c2 b+ A& l 5)问问题最好能带代码。
" Z8 k3 p1 B/ X0 q$ L5 h
9 j' S, T1 ]2 j/ ~ 6)不要说“编译通过,可是运行时...",因为编译错误和运行错误可能根本没有关系。 一般来说,编译是语法问题,而运行是逻辑问题。
1 {- g- M/ P$ E, t+ K' U3 W9 r; \& D/ }' e) s* X! s
7) 书看千遍不如做程序一遍,应该尽量尝试去写程序。 " a. ^0 Q# {* s" l
8 w) v; H& K; W1 }# o
8)做程序千个不如做好程序一个。应该尽量完善你现在做的程序,而不要不断开新的计 划,而每个计划都虎头蛇尾。 / I i& f, N1 h4 Z
1 G& {, z) E* j( n( M1 p
9)要想到你不是一个人写程序,而是和大家一起写程序。
6 c9 i( q" `8 @% B$ d0 E4 }( P% a- K* k" Z; ^; e- _0 q
10)高深的技巧虽然显示了高深的本领,但是对于合作往往是有害的,应该尽量写出简 单易读的代码。 * u( d5 H% M$ U8 g2 A
$ G2 K4 ?* i' y$ T; X8 h2 I, v [ 11)编制程序应该尽量做到自注释,即代码本身一读就懂,好象自己在说明自己的逻辑一样。 1 K8 B& \: w/ L/ Q+ D$ Y: {; |$ S
" b, h6 y& i$ x" |2 Z 12)复杂的代码如果实在做不到自注释,应该给出适量的注释。
& f) F" ^1 u+ M5 u
8 I, \' J, x$ [( ~+ z$ S8 ] { 13)注释在修改代码的时候应该相应修改,不能用陈旧的注释去误导别人。 ; a) p3 ^; P0 w. N* ^# a
$ |8 }4 k) b& X 14)代码应该尽量可重用,相同功能的代码应该由相同的函数完成,重要函数应该给出调试信息,以便调试时及早发现问题。 % O e0 R, X- ]- P
9 i+ K2 p! R+ b1 ]; [ 15)应该尽量写小函数,每个函数尽量不要超过40行或者更少。这样不用滚动屏幕也许就可以读完整个函数。 3 o$ D& t' F/ x3 b
& N( M5 i/ P" b! p" S6 ?8 R2 A 16)对于switch语句,尽量不要有过多的分支,如果分支太多,可以考虑用跳转表。
# `- Z( R3 ~1 }* |+ T
. O+ v: l1 G" @4 S 17)尽量少使用一些有争议的语句,如goto和三目运算符,既然有争议,它肯定有一定的缺点。 . `+ u/ F% O9 w* H/ A
1 C& w: @% H, Q- ~# a2 j4 W
18)对于goto,许多工程师技术高到可以合理使用,而不至于导致问题。但是你的程序并不一定给你同水平的人看和修改,他们可不能保证合理的读和修改这些相关代码。 & i8 K" n t0 t. y/ Y) g2 n
4 _2 r Z; k/ R, F) K- L0 ^; ^ 19)代码编写时应该有一定的格式,其基本要求是对理解代码有一定帮助。
. g# s8 P {* e7 S" r( ~' [1 a4 b3 X. n3 U% S* g
20)如果数据是多个模块共有的,应该提供一个封装的类来管理它,并提供一个合适的接口给各个模块。这样,如果数据内容有重大修改,则只要接口不变,基本上可以保证程序不要很复杂的修改。 0 }( b0 V9 {1 B' X0 L2 g4 [7 o
0 j, A9 |! _6 t2 D+ }( y 21)应该尽量考虑到数据的并发控制。
# T' P( z j6 d6 Y- i5 V) K
8 D7 [$ r% m: Y 22)数据的并发控制应该封装在接口内,而不要暴露给其他模块,这样可以减少因为并发原因导致的程序死锁。 6 ^0 D% J7 z& K4 j
k/ G g7 Z, M7 J
23)数据本身结构不可以太复杂。应该尽量把不相关的数据分割成为两组数据。 % T0 l4 t: S3 ~
7 m1 o I. H- z$ _
24)对于数据量比较大的情况,应该考虑数据库。
2 F% ?. n; Z( C8 ^
% ~7 Q. D) G, S 25)数据库接口应该采用标准ODBC或者ADO接口,尽量不要根据实际数据库DBMS提供的接口来处理,因为你可能在实际使用中更换DBMS。
) S1 h O9 s. F. w; R
1 z# o r! P; `, D) S9 e 26)小的数据可以考虑文件,文件路径应该必须设计成相对路径。
; t Z9 d% ?; M9 g% s# v3 C8 a" `" d& b* v1 Z: c3 ^3 G2 m- j* h$ V
27)在一个函数中,应该尽量打开文件后使用完后立刻关闭,这样其他程序可能使用文件。
" B/ G3 R8 `! y6 a4 t
2 ]) X4 C% z$ v# I' s 28)不要尝试把文件全部读到内存中,应该分次处理大文件。
6 @) H: E. B& M3 I
; b" i' _( S% A; w: v5 l 29)编写程序应该提供相关的测试程序,以提供测试手段。 . @; P5 }: t- l; r6 s% W2 {% X
( j& b1 _: x& I6 F% m; K; L
30)应该考虑代码、函数的使用情况,不要超越函数可以使用的范围使用之。 |
zan
|