`
ruyangit
  • 浏览: 18772 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

程序员之路──关于代码风格

 
阅读更多

优秀的代码风格如同一身得体的打扮,能够给人以良好的印象。初学程序设计,首先必须建立良好的编程习惯,这其中就包括代码风格。本文就代码风格中的几个重点问题进行了讨论,并在文后给出了一份优秀的代码作为风格模板。代码风格不必花费太多专门的时间研究,在使用中不断模仿模板代码,轻轻松松就能写出“专业的代码”。



一、80字符,代码行极限

  无论时空怎么转变,世界怎样改变,一行80字符应始终铭记心间。古老的Unix终端以80列的格式显示文本,为了让源代码与手册具有最佳的可读性,Unix系统始终坚持着80列的传统。80列不多不少,足够写出一行有意义的代码,同时也足够显示在终端屏幕,足够打印在A4纸上。虽然时至今日,我们的屏幕分辨率早已足够高,一行能够显示的内容远超超过80字符,但我们的优秀传统已经形成──几乎所有的Unix/Linux内核源代码以及联机用户手册都严格地遵守着80列极限。如果你正好在使用Windows平台下的Dev C++,你是否有注意到代码编辑框里那条细细的灰色竖线?不错,那正是代码行极限。除了HTML、XML等冗长繁复的标记式语言,几乎所有的语言都需要严格遵守代码行极限,这包括C、C++、Java、C#、Python、PHP等等。不过有时,比如当PHP跟HTML打交道的时候,这个限制是可以暂时放松的。过长的代码行总是不好的,好的代码要始终保持苗条的身材。



二、Tab还是Space,众说纷纭的缩进方式

  代码离不开缩进,关于缩进主要有两个争论,一个是该用空格(Space)还是用制表符(Tab),另外一个是该用4格缩进还是8格缩进甚至都不是。

  先来谈谈Space与Tab的问题。坚持用Space的程序员会告诉你,如果你从来都不用Tab,那么你的代码放到所有的地方看都是一样的。没错,这是用Space缩进的优点,可惜的是,这是它唯一的优点。代码层次越多,内层代码最前面的缩进便越多,这意味着你需要敲很多很多次空格。即使你能忍受不厌其烦地按空格键直到它坏掉,你也一定会被IDE总是自作聪明地插入一些Tab字符的行为烦恼不已。建议总是使用Tab缩进,因为几乎所有的代码(不仅仅是C代码)都在使用Tab缩进。

  Tab到底是4格还是8格?这是Tab缩进会被某些人诟病的根源。当你写程序时使用的Tab大小与别人读程序时使用的Tab大小不同时,再漂亮的排版也会变得杂乱无章。标准的Tab是8格的,而不幸的是,几乎所有的Windows平台下的IDE,包括Visual Studio、Dev C++,甚至跨平台的Eclipse等,都默认使用4格Tab。我使用的FreeBSD系统的所有的内核源代码都采用8格缩进,所以我一直坚持使用8格缩进。也许你不习惯太大的间距,如果不是在Unix平台下,或者不是C语言,那就采用4格Tab吧。如果你在Unix下编写C代码,使用8格的标准Tab是更好的习惯。



三、折行原则,容易被忽略的角落

  既然有代码行极限,很多情况下我们不得不断开一个完整的代码行,这就带来了一个问题:折行后应该如何缩进?好的做法是,第一次折行后,在原来缩进的基础上增加1/2的Tab大小的空格,之后的折行全部对齐第二行。可能这样的文字描述过于晦涩了,还是举个例子罢(以8格缩进为例):

if (value > a && value > b && value > c && value < d && value < e && value < f value < h && value < h) { /* 注意折行后的缩进 */ value = value + 1; value = value * value * value * value * value * value * value * value * value * value + value * value * value * value * value * value * value * value; /* 注意再次折行后的缩进 */}
  显然这个段代码没有任何实际用处,只是为了说明折行缩进而编造的。



四、无处不在的空格,无处不在的空行

  需要空格的位置有:
  1)if、while、switch等关键字与之后的左括号(之间。
  2)左花括号{之前。
  3)双目运算符两侧,例如p == NULL。
  4)逗号,与分号;之后,例如for (i = 0; i < 10; i++)。   

  不要空格的位置有:
  1)函数名与之后的左括号(,包括带参数的宏与之后的左括号(,例如max(a, b)。
  2)分号;与冒号:之前。
  3)左括号(右边,右括号)左边,例如if (p == NULL)。

  需要空行的位置有:
  1)函数的定义之前、函数的定义之后
  2)一组联系紧密的代码段之前和之后

  这些规则并不完全,当你碰到上面没有列举出来的情况时,请参考本文提供的模板代码。



五、左花括号的争议──换行乎?不换乎? 

  这又是一个仁者见仁智者见智的问题了。从使代码更清晰的角度看,作为代码段开头标识的左花括号{应该另起一行:

if (p == NULL){ printf("error!\n"); exit(0);}
  可是,这看起来实在不够紧凑,所以大部分的C代码(至少Unix上如此)都采用了这样的方式:

if (p == NULL) { printf("error!\n"); exit(0);}
  我的建议是采用后者,这会使你的代码显得更加紧凑,也更加专业。需要说明一个特例,在定义函数时,我们总是要给左花括号{换行:

static intmaxint(int a, int b){ return a > b ? a : b;}


六、坚持美观、灵活对待

  代码风格远远不止上面提到的五点,事实上,很多公司都有规定的代码风格,包括命名规则、缩进规则等。如果你在一个开发团队中,应该始终以团队的标准为主,而如果你只是在学习C语言并试着形成自己的代码风格,我将在这里给一份最专业的源代码供你参考。你的任何疑问,在这份代码里一定可以找到答案:Code Style(注意查看时将Tab设置为8格)。这份代码来自优秀的FreeBSD操作系统内核源代码(版本6.2),你一定不会置疑它的权威性。更多内容请参考FreeBSD内核代码编写规范,你也许需要一些耐心才能读完这篇英文文档。

分享到:
评论

相关推荐

    程序员之路———关于代码风格

    程序员之路,始于对代码风格的敬畏和遵守。良好的代码风格是优秀程序员的必备素质,它关乎个人代码的可维护性,也关乎团队合作的效率。 首先,代码行极限是代码风格中一个古老而重要的议题。80字符的限制起源于Unix...

    免费下载:C语言难点分析整理.doc

    程序员之路──关于代码风格 这部分探讨了代码风格的重要性。 ### 64. 指针、结构体、联合体的安全规范 这部分提供了一些确保指针、结构体和联合体使用的安全指南。 ### 65. C指针讲解 这部分全面介绍了C语言中的...

    C语言难点分析整理

    63. 程序员之路──关于代码风格 343 64. 指针、结构体、联合体的安全规范 346 65. C指针讲解 352 66. 关于指向指针的指针 368 67. C/C++ 误区一:void main() 373 68. C/C++ 误区二:fflush(stdin) 376 69. C/C++ ...

    高级C语言 学完C语言来看这个绝对收获

    程序员之路──关于代码风格 良好的代码风格对于编写可读性强、易于维护的程序至关重要。 #### 60. 指针、结构体、联合体的安全规范 安全规范旨在避免常见的编程错误,确保程序的稳定性。 #### 61. C指针讲解 ...

    高级C语言.PDF

    C语言编程准则之稳定篇 ............................................................................................................ 96 21. C语言编程常见问题分析 ..........................................

    C语言-编程技巧-谈谈代码风格──谈谈缩进

    其中,代码风格扮演着不可或缺的角色,而缩进,则是代码风格的精髓所在。在这篇文章中,我们将深入探讨C语言中缩进的奥秘,了解如何正确地使用缩进来提升我们的编程技艺。 首先,我们不得不承认,良好的代码风格对...

    阿里Java代码规范 视频教程 下载5.zip

    阿里Java代码规范 视频教程 下载 ├─1-命名风格,取个合理名字的重要性 │ 1-团队介绍及课程介绍.mp4 │ 2-命名风格(1).mp4 │ 3-案例展示.mp4 │ 4-命名风格(2).mp4 │ 5-常量定义.mp4 │ 6-代码格式.mp4...

    阿里Java代码规范 视频教程 下载1.zip

    阿里Java代码规范 视频教程 下载 ├─1-命名风格,取个合理名字的重要性 │ 1-团队介绍及课程介绍.mp4 │ 2-命名风格(1).mp4 │ 3-案例展示.mp4 │ 4-命名风格(2).mp4 │ 5-常量定义.mp4 │ 6-代码格式.mp4...

    阿里Java代码规范 视频教程 下载4.zip

    阿里Java代码规范 视频教程 下载 ├─1-命名风格,取个合理名字的重要性 │ 1-团队介绍及课程介绍.mp4 │ 2-命名风格(1).mp4 │ 3-案例展示.mp4 │ 4-命名风格(2).mp4 │ 5-常量定义.mp4 │ 6-代码格式.mp4...

    阿里Java代码规范 视频教程 下载2.zip

    阿里Java代码规范 视频教程 下载 ├─1-命名风格,取个合理名字的重要性 │ 1-团队介绍及课程介绍.mp4 │ 2-命名风格(1).mp4 │ 3-案例展示.mp4 │ 4-命名风格(2).mp4 │ 5-常量定义.mp4 │ 6-代码格式.mp4...

    阿里Java代码规范 视频教程 下载3.zip

    阿里Java代码规范 视频教程 下载 ├─1-命名风格,取个合理名字的重要性 │ 1-团队介绍及课程介绍.mp4 │ 2-命名风格(1).mp4 │ 3-案例展示.mp4 │ 4-命名风格(2).mp4 │ 5-常量定义.mp4 │ 6-代码格式.mp4...

    双11互联网电商Java秒杀解决方案 视频教程 下载 太大存入百度云盘2.zip

    阿里Java代码规范 视频教程 下载 ├─1-命名风格,取个合理名字的重要性 │ 1-团队介绍及课程介绍.mp4 │ 2-命名风格(1).mp4 │ 3-案例展示.mp4 │ 4-命名风格(2).mp4 │ 5-常量定义.mp4 │ 6-代码格式.mp4...

    双11互联网电商Java秒杀解决方案 视频教程 下载 太大存入百度云盘5.zip

    阿里Java代码规范 视频教程 下载 ├─1-命名风格,取个合理名字的重要性 │ 1-团队介绍及课程介绍.mp4 │ 2-命名风格(1).mp4 │ 3-案例展示.mp4 │ 4-命名风格(2).mp4 │ 5-常量定义.mp4 │ 6-代码格式.mp4...

    双11互联网电商Java秒杀解决方案 视频教程 下载 太大存入百度云盘1.zip

    阿里Java代码规范 视频教程 下载 ├─1-命名风格,取个合理名字的重要性 │ 1-团队介绍及课程介绍.mp4 │ 2-命名风格(1).mp4 │ 3-案例展示.mp4 │ 4-命名风格(2).mp4 │ 5-常量定义.mp4 │ 6-代码格式.mp4...

    双11互联网电商Java秒杀解决方案 视频教程 下载 太大存入百度云盘4.zip

    阿里Java代码规范 视频教程 下载 ├─1-命名风格,取个合理名字的重要性 │ 1-团队介绍及课程介绍.mp4 │ 2-命名风格(1).mp4 │ 3-案例展示.mp4 │ 4-命名风格(2).mp4 │ 5-常量定义.mp4 │ 6-代码格式.mp4...

    write clean code

    从【部分内容】中可以看出,这本书在出版和分发过程中,是由多人合作整理完成的,可能会存在一些文字或代码风格上的差异,例如指针声明的两种写法:一种是星号(*)与类型说明符相连,另一种是星号与变量名相连。...

    复刻李峋爱心的代码源码.zip

    标题中的"复刻李峋爱心的代码源码.zip"表明这是一个包含了某个人(可能是程序员或开发者)复现的李峋(可能是一个公众人物或者代码创作者)爱心代码的源码文件。这种代码通常是为了某种视觉效果或者情感表达而设计的...

    单点登录源码

    | ├── zheng-upms-dao -- 代码生成模块,无需开发 | ├── zheng-upms-client -- 集成upms依赖包,提供单点认证、授权、统一会话管理 | ├── zheng-upms-rpc-api -- rpc接口包 | ├── zheng-upms-rpc-...

    Golang:Golang回购尝试以一种简单的方式进行准备

    在编程领域,Go语言,又称为Golang,是由Google开发的一种静态类型的、编译式的、垃圾回收的、并发型且具有C/C++风格语法的编程语言。本篇将重点讨论如何在Golang中进行包管理和回购尝试的准备工作,以便于项目开发...

Global site tag (gtag.js) - Google Analytics