没有合适的资源?快使用搜索试试~ 我知道了~
这是一个讲述linux内核编程风格的文档,非常经典
资源详情
资源评论
资源推荐
Linux 内核编码风格
(编程代码风格推荐)
这是翻译版本,英文原版是 源码 文件夹下的
一个良好风格的程序看起来直观、美观,便于阅读,还能有助于对程序的理解,
特别在代码量 比较大情况下更显现编码素质的重要性。相反没有良好的风格的
代码读起来难看、晦涩,甚至有时候一个括号没对齐就能造成对程序的曲解或
者不理解。我曾经就遇 见过这样的情况,花费了很多不必要的时间在程序的上
下文对照上,还 了半天没理解的程序。后来直接用 给他
转换格式来看了。特此转过来一个关于代码风格的帖子分享一下~
内核编码风格
这是一份简短的,描述 内核首选编码风格的文档。编码风格是很个人化
的东西,而且我也不愿意把我的观点强加给任何人,不过这里所讲述的是我必
须要维护的代码所遵守的风格,并且我也希望绝大多数其他代码也能遵守这个
风格。所以请至少考虑一下本文所述的观点。
首先,我建议你打印一份 的编码规范,然后不要读它。烧掉它,这是一
个很高调的具有象征意义的姿态。
!
""""""""""第一章:缩进
制表符是 个字符,所以缩进也是 个字符。有些异端运动试图将缩进变为
#(乃至 $)个字符深,这跟尝试着将圆周率 %& 的值定义为 ' 没什么两样。
理由:缩进的全部意义就在于清楚的定义一个控制块起止于何处。尤其是当你
盯着你的屏幕连续看了 $( 小时之后,你将会发现大一点的缩进将会使你更容
易分辨缩进。
现在,有些人会抱怨 个字符的缩进会使代码向右边移动的太远,在 ( 个字
符的终端屏幕上就很难读这样的代码。这个问题的答案是,如果你需要 ' 级以
上的缩进,不管缩进深度如何你的代码已经有问题了,应该修正你的程序。
简而言之, 个字符的缩进可以让代码更容易阅读,还有一个好处是当你的函
数嵌套太深的时候可以向你提出告警。请留意这个警告。
在 语句中消除多级缩进的首选的方式是让“ )和从属于它的
“ )标签对
齐于同一列,而不要“两次缩进”“ )标签。比如:
"""""" * +,-
"""""" ..!
"""""" ..!
""""""""""//0'(1
""""""""""1
"""""" .2.!
"""""" ..!
""""""""""//0$(1
""""""""""1
"""""" .3.!
"""""" ..!
""""""""""//04(1
""""""""""56765
""""""7!
""""""""""1
""""""8
不要把多个语句放在一行里,除非你有什么东西要隐藏:
""""""7*,9 1
""""""9 9:1
也不要在一行里放多个赋值语句。内核编码风格超级简单。就是请避免使用怪
异的表达式。除了注释、文档和 3; 之外,不要使用空格来缩进,前面的
例子是例外,是有意为之。
选用一个好的编辑器,不要在行尾留空格。
""""""""""第二章:把长的行和字符串打散
编码风格的意义就在于使用平常使用的工具来维持代码的可读性和可维护性。
每一行的长度的限制是 ( 列,我们强烈建议您遵守这个惯例。
长于 ( 列的语句要打散成有意义的片段。每个片段要明显短于原来的语句,
而且放置的位置也明显的靠右。同样的规则也适用于有很长参数列表的函数头。
长字符串也要打散成较短的字符串。唯一的例外是超过 ( 列可以大幅度提高
可读性并且不会隐藏信息的情况。
:7*,
-
""""""7*,
""""""""""<*3=>9?>&@? <
@
""""""""""""""""""""""""""""""""@'< !A!A@
""""""""""""""""""""""""""""""""@!AB@,1
""""""
""""""""""9 1
8
""""""""""第三章:大括号和空格的放置
语言风格中另外一个常见问题是大括号的放置。和缩进大小不同,选择或弃
用某种放置策略并没有多少技术上的原因,不过首选的方式,就像 3
和 > 展示给我们的,是把起始大括号放在行尾,而把结束大括号放在行
首,所以:
""""""7* ,-
""""""""""
""""""8
这适用于所有的非函数语句块(7、 、7、、)。比如:
"""""" *,-
"""""" 3CDE9!
""""""""""@@1
"""""" 3CDE9>=2CF=!
""""""""""@:@1
"""""" 3CDE9G=!
""""""""""@@1
""""""7!
""""""""""1
""""""8
不过,有一种特殊情况,命名函数:它们的起始大括号放置于下一行的开头,
这样:
""""""7*,
""""""-
""""""""""77
剩余16页未读,继续阅读
dennisqun
- 粉丝: 0
- 资源: 5
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
评论0