简洁代码--函数

代码整洁之道笔记

[TOC]

函数

短小

每个函数都应该行数越少越好,同时缩进层级也不能太多,尽量局限于一级。

只做一件事

函数只做一件事情,起码在抽象层级上只做一件事情。

public static String RenderPageWithSetupsAndTeardowns(
    PageDate pageData, boolean isSuite) throws Exception {
    if (isTestPage(pageData)) {
        includeSetupAndTeardownPages(pageData, isSuite);

        return pageData.getHtml();
    }
}

该函数有三个步骤:

  1. 判断是否为测试页面
  2. 如果是则 XXXXXX
  3. 渲染HTML页面
    但是这是在该函数名下的同一个抽象层的动作。

函数的抽象层级

向下规则:每个函数后面都跟着下一抽象层的函数,逐步向底层调用

函数命名

testTableHtml 比 RenderPageWithSetupsAndTeardowns 的命名好的多。
使用描述性的名称。
使用动名词对

writeField(name)  比 write(name) 更加清楚的说明要写入的是Field

函数参数

当然是越少越好,参数越少,写测试用例也越轻松。

无副作用

public boolean checkPassword(String userName, String password) {
    //user auth
    //init session
}

上面的方法在验证用户信息成功之后初始化会话,存在时序耦合性。当别人想调用这个方法检查用户的时候就会有其他风险。所以改成下面的命名会好点

public boolean checkPasswordAndInitSession(String userName, String password) 

使用异常替代返回错误码

一个入口和一个出口

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 海到无边天作岸,山登绝顶我为峰。作为猿类的我们,对自己创造的代码有着一种天生的无比自信。这是好事~可是,对于我们的...
    独钓寒江雪_520阅读 4,676评论 0 0
  • 函数是实现程序功能的最基本单位,每一个程序都是由一个个最基本的函数构成的。写好一个函数是提高程序代码质量最关键的一...
    冰J冰阅读 12,456评论 2 4
  • 函数是代码组合的基本单位,高级编程语言的发展从结构化到面向对象,再到最近大有要复兴之势的函数式编程,函数都是组成这...
    TheAlchemist阅读 6,502评论 6 21
  • 前言 本规范是针对 Go 语言的编码规范,目的是为了统一项目的编码风格,提高源程序的可读性、可靠性和可重用性,从而...
    _张晓龙_阅读 5,942评论 5 21
  • 逆境就像一阵狂风。它不仅阻挡我们去某些我们本来能去的地方,还从我们手中夺走本来无法被夺走的东西,于是狂风过后,我们...
    泰勒的男人阅读 2,755评论 0 0