《代码整洁之道》笔记(四)格式

本文探讨了代码格式的重要性,提出了一系列提高代码可读性和维护性的建议。包括保持代码整洁、一致,采用统一的格式规则,以及如何通过垂直和横向格式增强代码的沟通效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

当有人查看底层代码实现时间,我们希望他们能被代码的整洁、一致所震惊,而不是如看到鬼画符一般。我们应该保持良好的代码格式,应该选用一套管理代码格式的简单规则,然后贯彻这些规则。如果在团队中工作,则团队应该采用同一套的简单的格式规则。

格式的目的

代码格式很重要,必须严肃对待。它关乎沟通,而沟通是专业开发者的头等大事。

 

那么,哪些代码格式相关方面能帮我们最好的沟通呢?

1. 垂直格式

用大多数为200行、最长500行的单个文件构造出色的系统是可能的,尽管这并非不可违背的原则,也应该乐于接受。短文通常比长文件易于理解。

(1)向报纸学习

一篇好的报纸文章,内容是从上到下循序渐进的,第一段往往是故事的大纲,再往下阅读,细节才会渐次增加。

源文件也应该像读报纸那样,名称应当简单且一目了然,名称本身应该足够告诉我们是否在正确的模块中。最顶部应该给出高层次概念和算法,细节往下逐步展开。

(2)概念间垂直方向上的区隔

几乎所有代码都是从上往下读,从左往右读。每行展现一个表达式或一个子句。每组代码行展示一条完整的思路。这些思路用空白行区隔开。每个空白行都是一条线索,标识出新的独立概念。

(3)垂直方向上的靠近

如果说空白行隔开了概念,靠近的代码则暗示了它们之间的紧密关系。所以,关系紧密的代码应该互相靠近。

(4)垂直距离

 关系密切的概念应该互相靠近,显然,这条规则并不适用于分布在不同文件中的概念。除非有很好的理由,否则就不要把关系密切的概念放到不同的文件中。

对于那些关系密切、放置于同一源文件中的概念 ,应尽量避免读者在源文件中跳来跳去。

①变量声明

变量声明应该尽可能靠近使用位置。因为函数很短,本地变量应该在函数顶部出现。

②实体变量

实体变量应该在类的顶部声明

③相关函数

某个函数调用了另外一个,就应该把它们放到一起,而且调用者应尽可能放在被调用者上面。这样,程序就有了自然的顺序,极大的增强了整个模块的可读性。

④概念相关

概念相关代码应该放到一起,相关性越强,彼此之间的距离应该越短。

(5)垂直顺序

一般而言,我们想自上而下展示函数调用依赖顺序,这样就建立了一种自顶向下贯穿代码模块的良好信息流。

2. 横向格式

在横向上,应尽力保持代码短小

(1)水平方向上的区隔与靠近

我们使用空格将彼此紧密相关的事物连接到一起,也用空格字符把相关性较弱的事物隔开。

①在赋值操作前后加上空格字符,加强左边和右边的分割效果。

②不要在函数名和左圆括号中间加空格,因为函数与其参数密切相关,如果分开,就会显得互无关系。

③函数调用括号中的参数用空格一一隔开,强调逗号,表示参数是互相分离的。

④在运算符周围加或不加空格来表示优先级。

(2)水平对齐

水平对齐其实并没有什么作用,更像是在强调不重要的东西。

(3)缩进

源文件是一种继承结构,而不是大纲结构。其中的信息涉及整个文件、文件中每个类、类中的方法、方法中的代码块,也涉及代码块中的代码块。这种继承结构中每一个层级都有一个范围,名称可以在其中声明,而声明和执行语句也可以在其中解释。

要让这种范围式继承结构可见,就需要缩进处理。在文件的顶层语句,例如大多数类声明,根本不缩进,类中的方法对应该类缩进一个层级。方法的实现相对方法的声明缩进一个层级。代码块的实现相对于其容器代码块缩进一个层级,以此类推。

(4)空范围

有时,while或者for语句的语句体为空,尽量不要使用这种结构,如果无法避免,就确保空范围体的缩进,用括号包围起来。

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值