设为首页收藏本站|繁體中文 快速切换版块

 找回密码
 立即加入
搜索
查看: 1245|回复: 4

[讨论] 15个编程好习惯

[复制链接]
  • TA的每日心情
    慵懒
    2016-4-21 12:07
  • 签到天数: 3 天

    连续签到: 1 天

    [LV.2]偶尔看看I

    累计签到:3 天
    连续签到:1 天
    发表于 2011-3-23 22:12:10 | 显示全部楼层 |阅读模式

    马上加入,结交更多好友,共享更多资料,让你轻松玩转电力研学社区!

    您需要 登录 才可以下载或查看,没有账号?立即加入

    ×

    1. 动手编码之前,你需要对要编码实现的解决方案有一个正式的或粗略的设计。永远不要在没有任何设计的前提下就开始编码,除非所编代码不重要。

    2. 优秀的代码文档跟编程语言知识一样重要。在代码源文件中,为每个主要的代码段添加注释,解释代码的基本逻辑。最好注明程序的构建和修改日期,以及修改的原因也是非常有必要的。- g* J7 }0 I0 k% [0 Q7 t

    4 R; Z: {# N! P- s1 s5 j0 w# @  3. 维护程序的各个版本同样重要。当前有些编程工具都自带一个版本管理工具。无论你什么时候改变自己的程序,它们都会将其保存为.bak文件。% L  P7 y% c+ s9 s' q; p

    & _1 [# d3 G/ ]+ Y8 o, K  我的方法是为每个程序维护三个不同的版本。比如说,我有一个名为program.c的文件,这个文件同时也被其他项目组成员使用。我把这个文件复制为 program.c.old作为备份文件,并且当我修改时,我会备份另一个名为program.c.wrk的副本文件。当成功完成修改时替换 program.c.wrk文件。
    # A. S' f3 t4 P. W) C& N, f$ |+ H8 p* ?# G6 f% v
      你还可以给自己的程序版本添加一个日期或一些注释,像program260505.c或programReadFnWrking.c。1 E. c: ^6 n: [0 c" {
    6 N' @) D+ s6 K( C# V# t
      4. 如果工程包含多个源文件,则声称一个README文件,注明每个源文件、数据文件、临时文件以及日志文件(如果有的话)的作用。你还可以注明编译和运行步骤。
    1 O3 E/ S4 h. ~7 _6 K2 n$ e4 h
    4 D4 _/ Q$ u2 ~) ]- T8 J  5. 有时候,你一定想知道为什么IF语句没有得到预想的结果。可能你使用的是等号,也就是“=”,而不是条件判定符号“==”。一个比较好的办法是用相反的顺序写条件语句。因此,你的条件语句应该如下:
    7 P$ n9 e+ x0 o4 X; g7 z8 T. d" X  `. r$ M
      if(10==i)…因此,如果你错误地写成了单个等于号,在编译的时候也能检查出来并报错。, t1 y0 M- `2 F7 O8 Z; w

    9 X0 z( x1 H+ p- n( \  6.使用循环和条件语句时,先把左右括号对应起来,然后再在里面写其他语句。也就是:" Z' U1 d( s* l& I

    - |) p" w4 X) G: v: \7 k" [: c: M代码: 1 for(int i=0;i<10;i++)2 {4 printf(“i=%dn”,i);3 }   注:每一行开头的数字表明写循环代码的顺序。
      d0 x7 [( t7 K, [
    6 M( _, G, A, z3 ?$ J  7. 避免使用幻数(magic numbers)。例如,不要写
    ; n: S( `- i* y0 z3 `) `7 G; ~8 ?. F9 S6 b% o0 a5 E  E
    代码: circleArea = 3.14 * pow(radius,2); 而要使用如下代码:
    * E- r0 X- p$ U* J) P# F8 k( V9 Z8 @9 v) o2 W: Y! |& K1 n- O
    代码: #define PI 3.14 circleArea = PI * pow(radius,2);   & b, J6 _8 R8 h1 m! u6 f7 G
      8. 使用有意义的变量和函数名称。例如,使用‘radius’来代替圆的半径,而不是用‘r’来表示。同样,函数名‘calculateArea’要比其他任 何隐晦的缩写要好得多。匆忙之下,我们也许会使用缩写的变量名,但一开始节省时间的话,之后会浪费更多的时间,去猜测缩写变量名代表什么。(编注:)
    5 b1 E2 V  e" ~0 P" j3 m9 H. u. m) J
      9. 为后面的调试使用打印语句,这是个好习惯。但是,当完成最后代码后,去掉这些语句,有时也是一项危险的任务。添加一个方法,用于输出调试信息。当最终版本生成时,只要把这个方法注释掉就行。因此,只在一个地方做修改就可以了。# p& [. I! E$ ^% |- o. l1 h
    , k9 V0 o7 v; z4 C
      10. 代码编写完之后,开始优化代码。之前声明的一些变量,现在可能没用了。同样,并不依赖循环的一些声明可以移到循环模块之外去。扎实的编译知识同样会对以后的代码优化有所帮助。4 H2 y  F# {2 |4 a. l
    ' ?8 h( I% a' C% J) e9 T
      11. 对自己的操作系统和硬件要有足够的了解,你可以从资源占用等方面提升程序的性能。
    ; e) p3 {0 B7 v4 \2 O* `7 d& s% v" }: g
      12. 编写代码时要合理使用缩进,以使代码清晰可读。6 H5 V# n; r) _( U
    ' t( @8 S9 i" ]2 [
      13. 把项目文件放到SOURCE、HEADERS、MAKE、EXES等不同的文件夹中。
    6 g! ~* P' V& j3 \( H" {/ \
    5 f4 F  }0 ]' M4 R  14. 研究别人编写的代码。这可以让你学习到新的编程技术,以及他们解决和你相同的任务时所使用的方法。$ [) L3 E* U- A, ?: m: d) f. [

    # e% ]- G( s! |' s4 k5 @: R  15. 最后一条(但不是最不重要的一条),备份源代码文件,这样当硬盘出错或相同的问题发生时,不至于前功尽弃。% O2 w/ J1 }' |! Z: t

    3 `) E! m* W4 Y. j1 z  附加:补充一条,坚持使用一种命名模式。如果你打算用匈牙利命名法,那就坚持并广泛使用,否则将适得其反。参见微软资深工程师 Eric Lippert 的这篇文章《阅读代码不简单》。
    - ?( i; i4 o8 S- z9 d( \

    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    楼主热帖
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】

    该用户从未签到

    尚未签到

    发表于 2011-3-24 09:24:42 | 显示全部楼层
    路过,学习了
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】

    该用户从未签到

    尚未签到

    发表于 2011-4-19 23:19:21 | 显示全部楼层
    学习了
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】
  • TA的每日心情
    开心
    2016-4-12 16:48
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]初来乍到

    累计签到:1 天
    连续签到:1 天
    发表于 2011-12-7 17:48:33 | 显示全部楼层
    路过,看看...
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】
  • TA的每日心情
    开心
    2017-3-6 22:05
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]初来乍到

    累计签到:1 天
    连续签到:1 天
    发表于 2011-12-21 19:34:10 | 显示全部楼层
    很有用
    "真诚赞赏,手留余香"
    还没有人打赏,支持一下
    帖文化:【文明发帖 和谐互动】 社区精神:【创新、交流、互助、共享】
    您需要登录后才可以回帖 登录 | 立即加入

    本版积分规则

    招聘斑竹

    小黑屋|手机版|APP下载(beta)|Archiver|电力研学网 ( 赣ICP备12000811号-1|赣公网安备36040302000210号 )|网站地图

    GMT+8, 2025-2-23 16:43

    Powered by Discuz! X3.5 Licensed

    © 2001-2025 Discuz! Team.

    快速回复 返回顶部 返回列表