下沙论坛

标题: 【转帖】程序设计中的一些感悟 [打印本页]

作者: 煎饼    时间: 2003-7-28 17:35
标题: 【转帖】程序设计中的一些感悟
1)学习应该从基础打起,不要一开始就尝试最高深的技术。
5 q2 R* ]* Q# i2)每看一本书,不要说这章我以前学习过了,也掌握的很好,因此我可以跳过这一章看更重要的了。
, L6 d5 _+ \- k( i6 f3)对于作业,遇到不会的尽量不要立刻向别人请教。如果实在解决不了的问题,可以先完成你会的,然后把一些特别的难点提炼出来,向高手请教。
- z7 k% U! c- |3)不要指望书本和行家能帮你解决一切问题,因为并不是所有问题都能由别人教给你。
7 G; @1 ~! R# L; y) d: k6 A  _1 s% @% C9 U
4)向别人请教问题应该把问题说明白。对于错误提示信息应该原样提供出来,不要按自己理解的信息提供。因为既然你自己做不了,说明你理解一般都有问题。  [' G9 T* F7 j4 D% `9 b3 H2 q) B
5)问问题最好能带代码。
. r: k$ g& A0 e6)不要说“编译通过,可是运行时...",因为编译错误和运行错误可能根本没有关系。一般来说,编译是语法问题,而运行是逻辑问题。
) J$ q  G" U5 |0 z7) 书看千遍不如做程序一遍,应该尽量尝试去写程序。
& ?. K2 s/ v# r/ A: T( T; `7 l1 H9 ?8)做程序千个不如做好程序一个。应该尽量完善你现在做的程序,而不要不断开新的计划,而每个计划都虎头蛇尾。6 s, b) b9 l& u0 ^7 w) k1 C' A8 q) a
2 B# F" s' {% n7 A8 h: B
- f9 n/ S3 x3 g3 x
9)要想到你不是一个人写程序,而是和大家一起写程序。
- K% q. u3 c' r- `* o! a10)高深的技巧虽然显示了高深的本领,但是对于合作往往是有害的,应该尽量写出简单易读的代码。
2 m, I. F5 D" ]# x# V0 K9 g3 y11)编制程序应该尽量做到自注释,即代码本身一读就懂,好象自己在说明自己的逻辑一样。- D" ~4 Q8 u# x* J
12)复杂的代码如果实在做不到自注释,应该给出适量的注释。4 T7 h- u- U/ e! U
13)注释在修改代码的时候应该相应修改,不能用陈旧的注释去误导别人。
' h; z! I3 P4 E6 {14)代码应该尽量可重用,相同功能的代码应该由相同的函数完成,重要函数应该给出调试信息,以便调试时及早发现问题。% x) o0 `( E2 H
15)应该尽量写小函数,每个函数尽量不要超过40行或者更少。这样不用滚动屏幕也许就可以读完整个函数。6 q' R1 ^! q  A- K
16)对于switch语句,尽量不要有过多的分支,如果分支太多,可以考虑用跳转表。. n; z0 F- z  B/ f" }  u
17)尽量少使用一些有争议的语句,如goto和三目运算符,既然有争议,它肯定有一定的缺点。
" j$ S# }* d" `1 @) t( h$ e18)对于goto,许多工程师技术高到可以合理使用,而不至于导致问题。但是你的程序并不一定给你同水平的人看和修改,他们可不能保证合理的读和修改这些相关代码。4 \) c* ~" j+ L. @0 d2 a) a
19)代码编写时应该有一定的格式,其基本要求是对理解代码有一定帮助。
* g; v0 T  e$ H& e20)如果数据是多个模块共有的,应该提供一个封装的类来管理它,并提供一个合适的接口给各个模块。这样,如果数据内容有重大修改,则只要接口不变,基本上可以保证程序不要很复杂的修改。
% e8 t9 }' T, i" t21)应该尽量考虑到数据的并发控制。
; o& u; y: U* Q# @: \9 J22)数据的并发控制应该封装在接口内,而不要暴露给其他模块,这样可以减少因为并发原因导致的程序死锁。
! p' }1 @, _# T5 X9 l% ~23)数据本身结构不可以太复杂。应该尽量把不相关的数据分割成为两组数据。; `  M2 c# K  D/ f
24)对于数据量比较大的情况,应该考虑数据库。
$ I+ @$ f% r4 a* q7 y* A25)数据库接口应该采用标准ODBC或者ADO接口,尽量不要根据实际数据库DBMS提供的接口来处理,因为你可能在实际使用中更换DBMS。
( d( V3 ~! l1 e6 x! e7 f26)小的数据可以考虑文件,文件路径应该必须设计成相对路径。
* [6 U6 Q* B& f3 j4 {+ Q( b27)在一个函数中,应该尽量打开文件后使用完后立刻关闭,这样其他程序可能使用文件。
7 C, q' h- K0 ]28)不要尝试把文件全部读到内存中,应该分次处理大文件。
. f5 F' j9 H2 m# s29)编写程序应该提供相关的测试程序,以提供测试手段。3 i* M0 O6 R" m. A- V+ i
30)应该考虑代码、函数的使用情况,不要超越函数可以使用的范围使用之。
作者: 猴子很忙    时间: 2003-7-28 20:04
好。。。。1 ]$ q' i4 `& C5 D4 x
顶。。。
作者: yzhlinux    时间: 2003-8-5 15:53
第2条不对,如果自信,那么应该这样做: s; ^: S6 h$ y: q' c& [/ a5 g
第4条非常重要,问问题是一们艺术,这里可以体现你的用心和你的潜志$ t! n; U4 i( H+ A2 L! f4 G
第11条异常重要,但是太多人都相信和会努力去做第4条,但是对11条的努力往往在工作的时候放在脑后,往往认为,这里实在简单,不需要注释。4 K, N  ?0 F0 C. i! x/ u7 k0 x
对于17条,建议想又高深技术的人去仔细研究一翻,因为 3目运算和 goto 是非常有用,且在特定环境中其他语句无法比拟的。
7 R+ _/ B; q) u: b4 g增加两条(和上面一样都主要针对 C++/C 的程序员)
8 e: w' P: A$ c: V1 p) ]31,函数尽量短小,出特别情况控制在30行代码以内。即把大函数细分话。
( g. m' I; U& e32,任何时候只要时间允许,请把程序编写的过程和心得写成除了必要文档以为的一个手本 log,记录下你遇到的一切可以当作问题的问题,和你在过程中与别人的谈话。1 Y/ S( y  ^" I8 S: P0 Y





欢迎光临 下沙论坛 (http://bbs.xiasha.cn/) Powered by Discuz! X3.3