编码风格(C)学习--the practice of prigramming

风格

目的:使代码易读

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.注释

  • 不要写废话
  • 注释要与代码一致,及时更新
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值