Board logo

标题: 谈谈Linux内核驱动的编码风格(2) [打印本页]

作者: yuyang911220    时间: 2017-4-23 20:20     标题: 谈谈Linux内核驱动的编码风格(2)

缩进
1、除了注释、文档和Kconfig之外,使用Tab缩进,而不是空格,并且Tab的宽度为8个字符;
2、switch … case …语句中,switch和case具有相同的缩进(参考上文);
花括号
3、花括号的使用参考K&R风格。
如果是函数,左花括号另起一行:
否则,花括号紧接在语句的最后:
如果只有一行语句,则不需要用花括号:
但是,对于条件语句来说,如果一个分支是一行语句,另一个分支是多行,则需要保持一致,使用花括号:
空格
4、在关键字“if, switch, case, for, do, while”之后需要加上空格,如:
if (something)
5、在关键字“sizeof, typeof, alignof, or __attribute__”之后不要加空格,如:
sizeof(struct file)
6、在括号里的表达式两边不要加空格,比如,下面是一个反面的例子:
sizeof( struct file )
7、大多说的二元和三元运算符两边需要空格,如“= + – < > * / % | & ^ <= >= == != ?  :”;
8、一元运算符后面不要空格,如“& * + – ~ ! sizeof typeof alignof __attribute__  defined”;
9、在前缀自增自减运算符之后和后缀自增自减运算符之前不需要空格(“++”和“–”);
10、结构成员运算符(“.”和“->”)的两边不需要空格;
11、行尾不需要空格;
注释
12、使用C89的“/* … */”风格而不是C99的“// …”风格;
13、对于多行注释,可以参考下例:
Kconfig
14、“config”定义下面的语句用Tab缩进,help下面的语句再额外缩进两个空格,如:

15、多行的宏定义需要用“do .. while”封装,如:
函数返回值
16、函数返回值的定义最好也要遵循一定的章法。
如果函数的名称是一种动作或者命令式的语句,应该以错误代码的形式返回(通常是0表示成功,-Exxx这种形式的负数表示错误),如:
do_something()
如果函数的名称是判断语句,则返回值应该类似与布尔值(通常1表示成功,0表示错误),如:
something_is_present()




欢迎光临 电子技术论坛_中国专业的电子工程师学习交流社区-中电网技术论坛 (http://bbs.eccn.com/) Powered by Discuz! 7.0.0