风格
目的:使代码易读
1. 取个好名字吧
简练的,容易记忆的,最好是能拼读的,含有来自上下文和作用域的意义
全局变量使用具有说明性的名字,局部变量使用短名字
例如:给全局变量备注一个简短的注释:
int npending = 0; //curren length of input queue
常规的一些短名字:
- i,j 作为循环变量
- p,q 作为指针
- s,t 表示字符串
函数采用动作性的名字
now = date.getTime();
putcahr('\n')
布尔类型的命名应该清楚的反应返回值情况
下面是不好的额,不知道什么时候返回真,返回假
if (checkoctal(c))
改进一下:
这样就知道是八进制返回真 不是返回假
if (isoctal(x))
有的时候命名对的 但是实现错了。。。害人不浅
2.表达式和语句
- 采用一致的缩行风格
- 使用自然的表达式,能不加
!
或者其他符号就不加,尽量简洁应该写的你能大声念出来 - 加括号排除二义性,但是也不必加太多没必要的括号
下面这个本来可以不加括号 但是加了更好理解:
leap_year = y % 4 == 0 && y % 100 != 0 || y % 400 == 0;
leap_year = ((y%4 == 0) && (y%100 != 0)) || (y%400 == 0);
- 不要去滥用
? :
这类运算符
3.一致性和习惯用法
- 缩排一致,加括号的风格一致
- 修改别人代码时,不要改成自己的风格
习惯用法的循环是:
for (i = 0; i < n; i++)
array[i] = 1.0;
扫描链表的标准循环:
for (p = list; p != NULL; p = =->next)
...
无穷循环,一般是:
for (;;)
or
while (1)
常见的另一个惯用法:
while ((c = getchar()) != EOF)
putchar(c);
绝不要使用函数gets,因为你没有办法限制它从输入那儿读入内容的数量,常常会导致一个安全性的问题。
4.注释
- 不要写废话
- 注释要与代码一致,及时更新