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

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

[讨论] 15个编程好习惯

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

    连续签到: 1 天

    [LV.2]偶尔看看I

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

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

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

    ×

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

    2. 优秀的代码文档跟编程语言知识一样重要。在代码源文件中,为每个主要的代码段添加注释,解释代码的基本逻辑。最好注明程序的构建和修改日期,以及修改的原因也是非常有必要的。
    % I! P% F. t5 V" a) e. h2 ^
      Y( J5 t6 }) A' w$ q  3. 维护程序的各个版本同样重要。当前有些编程工具都自带一个版本管理工具。无论你什么时候改变自己的程序,它们都会将其保存为.bak文件。
    1 }0 t3 p, j; F' A: _# b7 V9 w$ f& H( A& P0 }- [$ v- c8 z1 K
      我的方法是为每个程序维护三个不同的版本。比如说,我有一个名为program.c的文件,这个文件同时也被其他项目组成员使用。我把这个文件复制为 program.c.old作为备份文件,并且当我修改时,我会备份另一个名为program.c.wrk的副本文件。当成功完成修改时替换 program.c.wrk文件。
    ! B& G7 y- ~& c( q# w+ B$ B. I# ?$ J% e
      你还可以给自己的程序版本添加一个日期或一些注释,像program260505.c或programReadFnWrking.c。. R* P# |' F* R. a+ y1 N

    + ]7 v/ L9 Z+ A% b) A7 w& e( I  4. 如果工程包含多个源文件,则声称一个README文件,注明每个源文件、数据文件、临时文件以及日志文件(如果有的话)的作用。你还可以注明编译和运行步骤。
    & }2 n' \9 X. d9 R4 C! p" C, I0 `8 ]- J0 r/ e! v7 z
      5. 有时候,你一定想知道为什么IF语句没有得到预想的结果。可能你使用的是等号,也就是“=”,而不是条件判定符号“==”。一个比较好的办法是用相反的顺序写条件语句。因此,你的条件语句应该如下:4 ~1 i# Q5 n( _2 P* a. y, W& d
    1 r) V' B5 g- P5 ]5 |) ]
      if(10==i)…因此,如果你错误地写成了单个等于号,在编译的时候也能检查出来并报错。
    & Y9 P  {0 S& C3 K- [& y1 h6 @/ {' M8 t% @, @5 u% d( [# b
      6.使用循环和条件语句时,先把左右括号对应起来,然后再在里面写其他语句。也就是:8 I8 _$ B" ^* a& x; Q; M3 z9 T

    / A! I% k) }5 K3 F, }3 J+ w代码: 1 for(int i=0;i<10;i++)2 {4 printf(“i=%dn”,i);3 }   注:每一行开头的数字表明写循环代码的顺序。
    9 [, t" s) n( m
    9 _$ I( j" P5 y  7. 避免使用幻数(magic numbers)。例如,不要写
    7 t2 h8 \2 G7 A
    ' Z# D5 u* b( T8 C5 T" X代码: circleArea = 3.14 * pow(radius,2); 而要使用如下代码:
    7 r* b6 K! \9 X2 v2 `0 D
    ' i% O$ ^5 P* q6 @) F代码: #define PI 3.14 circleArea = PI * pow(radius,2);   ; Z& S' ^6 ^0 X: m* J+ f& z
      8. 使用有意义的变量和函数名称。例如,使用‘radius’来代替圆的半径,而不是用‘r’来表示。同样,函数名‘calculateArea’要比其他任 何隐晦的缩写要好得多。匆忙之下,我们也许会使用缩写的变量名,但一开始节省时间的话,之后会浪费更多的时间,去猜测缩写变量名代表什么。(编注:)0 u! w: [- r$ n: T0 z( n$ [
    ; V' N4 f, o, w% q& B/ R6 `7 m( z* L
      9. 为后面的调试使用打印语句,这是个好习惯。但是,当完成最后代码后,去掉这些语句,有时也是一项危险的任务。添加一个方法,用于输出调试信息。当最终版本生成时,只要把这个方法注释掉就行。因此,只在一个地方做修改就可以了。, ~3 }" r3 A0 y9 z

    ! C1 B" [8 j# D9 e% C( B$ K' n  10. 代码编写完之后,开始优化代码。之前声明的一些变量,现在可能没用了。同样,并不依赖循环的一些声明可以移到循环模块之外去。扎实的编译知识同样会对以后的代码优化有所帮助。
    ! e4 `2 j9 R6 z' K) c$ r$ P! P; ~$ F. N1 h
      11. 对自己的操作系统和硬件要有足够的了解,你可以从资源占用等方面提升程序的性能。
    2 O9 J4 N- I+ I) d+ M9 a& b' O: D1 T7 ]& {1 Y$ P& H
      12. 编写代码时要合理使用缩进,以使代码清晰可读。; N# W8 M+ o- ^6 O1 G2 C
    2 J9 O' [+ |+ v% P. q2 |$ t; R, K# l
      13. 把项目文件放到SOURCE、HEADERS、MAKE、EXES等不同的文件夹中。
    , ]) X: _7 i% W" R, I* c% ]$ _8 B4 i2 w; B
      14. 研究别人编写的代码。这可以让你学习到新的编程技术,以及他们解决和你相同的任务时所使用的方法。
    + p  r6 B5 Z' u7 D
    & U% f7 D/ s2 [  15. 最后一条(但不是最不重要的一条),备份源代码文件,这样当硬盘出错或相同的问题发生时,不至于前功尽弃。
    ( X. D) I2 U/ p6 O  i  E. }$ T6 G2 j1 ^( {% G
      附加:补充一条,坚持使用一种命名模式。如果你打算用匈牙利命名法,那就坚持并广泛使用,否则将适得其反。参见微软资深工程师 Eric Lippert 的这篇文章《阅读代码不简单》。
    / j0 M  j; O- r* K3 ]! K

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

    该用户从未签到

    尚未签到

    发表于 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, 2026-3-16 13:53

    Powered by Discuz! X3.5 Licensed

    © 2001-2025 Discuz! Team.

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