码农修行:编写优雅代码的32条法则
上QQ阅读APP看书,第一时间看更新

法则03:保留个性

函数的第一个左括号“{”,是在和函数同一行的最右边。

还是另起一行放在最左边。

if、for、do…while、while、try…catch、switch…case等语句的括号也有如下三种风格。

风格一:左括号在第一行最右边。

风格二:左括号另起一行并与上一列对齐。

风格三:左括号另起一行并加一个Ta b。

等号“=”或其他各类运算符两边各加一个空格。

还是不要空格。

或者是加若干个空格让代码块保持对齐。

行尾的分号“;”前面加1个空格。

还是不加。

定义函数时,函数的名称和后面的小括号“(”之间要加空格。

还是不加。

上述这些风格如何选择?其实代码的可读性不会因为一个括号的位置或多少了几个空格而受到影响。我认为以上这些风格都是可行的。甚至在一个项目组中也不要对风格进行限定,要鼓励软件设计师有自己的个性。但需要注意的是,一旦选定了一种风格,就要一直使用它,让它成为你职业生涯的一种“标志”。

我们就来欣赏各位高手的编程风格吧!

下面是Windows编程大师Charles Petzold[4]的风格。他的代码看上去十分整齐。函数名和后面的小括号“(”之间有1个空格,所有分号“;”前面都有1个空格,所有大括号“{”都另起一行,相关联的代码块也都保持对齐,同时使用了匈牙利标记法。此外注意其代码缩进为5个空格,非常特别。

下面是Linux之父Linus Torvalds大神的风格。其缩进为1个Tab(对应8个空格),大括号“{”在while或if语句同一行的右边,if语句后的单行代码并没有使用大括号对“{}”。此外最为“霸气”的是直接用自己的名字命名了设备驱动层电梯调度算法的函数名(摘自Linux-2.4.0内核源码)。

当然关于代码风格我的建议是:作为普通软件设计师,很多时候需要“随和”一点,因为它并非原则性问题。虽然要形成自己的风格,但有时候“入乡随俗”也未尝不可。当新加入一个项目时,如果项目组没有明确要求代码风格,你可以按照自己的风格写代码。但如果项目组有明确的要求,那么就去适应该项目组的风格。

此外,如果你是项目管理者,我建议不要对代码风格有太多的限制,要鼓励软件设计师有自己的个性。