编程规范 --- 可读性
来源:互联网 发布:hmcl启动器找不到java 编辑:程序博客网 时间:2024/04/30 02:36
1:注意运算符的优先级,并用括号明确表达式的操作顺序,避免使用默认优先级。
说明:防止阅读程序时产生误解,防止因默认的优先级与设计思想不符而导致程序出错。
示例:下列语句中的表达式
word = (high <<8) | low (1)
if ((a | b)&& (a & c)) (2)
if ((a | b) < (c& d)) (3)
如果书写为
high << 8 | low
a | b && a& c
a | b < c & d
由于
high << 8 | low= ( high << 8) | low,
a | b && a& c = (a | b) && (a & c),
(1)(2)不会出错,但语句不易理解;
a | b < c & d= a | (b < c)& d,(3)造成了判断条件出错。
2:避免使用不易理解的数字,用有意义的标识来替代。涉及物理状态或者含有物理意义的常量,不应直接使用数字,必须用有意义的枚举或宏来代替。
示例:如下的程序可读性差。
if(Trunk[index].trunk_state == 0)
{
Trunk[index].trunk_state = 1;
... // program code
}
应改为如下形式。
#define TRUNK_IDLE 0
#define TRUNK_BUSY 1
if(Trunk[index].trunk_state == TRUNK_IDLE)
{
Trunk[index].trunk_state = TRUNK_BUSY;
... // program code
}
3:源程序中关系较为紧密的代码应尽可能相邻。
说明:便于程序阅读和查找。
示例:以下代码布局不太合理。
rect.length = 10;
char_poi = str;
rect.width = 5;
若按如下形式书写,可能更清晰一些。
rect.length = 10;
rect.width = 5; // 矩形的长与宽关系较密切,放在一起。
char_poi = str;
4:不要使用难懂的技巧性很高的语句,除非很有必要时。
说明:高技巧语句不等于高效率的程序,实际上程序的效率关键在于算法。
示例:如下表达式,考虑不周就可能出问题,也较难理解。
* stat_poi ++ += 1;
* ++ stat_poi += 1;
应分别改为如下。
*stat_poi += 1;
stat_poi++; // 此二语句功能相当于“ * stat_poi ++ += 1; ”
++ stat_poi;
*stat_poi += 1; // 此二语句功能相当于“ * ++ stat_poi += 1; ”
- 编程规范 --- 可读性
- 软件编程规范总则-4 可读性
- 华为软件编程规范学习(四)--可读性
- 华为软件编程规范学习(四)--可读性
- JavaScript编程规范-有利于效率和可读性
- C语言编程规范3: 可读性
- 华为C语言编程规范—可读性
- 华为C语言编程规范(5)—可读性
- 华为C语言编程规范(5)—可读性
- 软件编写规范(可读性)
- 华为软件编程规范和范例 2 —— 标识符命名和可读性
- 简图记录-C语言编程规范:可读性、安全性、可移植性
- 为可读性编程
- 编程语言的可读性
- Android 命名规范 (提高代码可读性)
- 代码规范_1:代码的可读性
- 注意代码的规范和可读性
- Android 命名规范 (提高代码可读性)
- BZOJ 2301 Problem B(x属于[a,b],y属于[c,d]满足gcd(x,y)=k的(x,y)的有序对数)
- iOS学习- 16 search tableview item - Todo App
- 通过服务器获取终端上应用软件更新数据的方法和系统
- Builder模式
- Java面试题之基础(1)
- 编程规范 --- 可读性
- screen ssh 上边虚拟窗口的运行
- myeclipse启动选择workspace的Launcher框
- 牛腩新闻发布系统
- STM32的时钟配置
- StringTokenizer类的使用
- Android加载大图的优化策略
- UniversalMusicPlayer 学习笔记(二)
- 面向对象_补充_封装_成员与局部变量_static关键字_Math随机数