热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

书籍《编写可读代码的艺术》学习

读书笔记——编写可读代码的艺术序.本书主要内容简化命名、注释和格式的方法,使每行代码都言简意赅梳理程序中的循环、逻辑和变量来减小复杂度并清理思路在函数级别解决问题,




读书笔记——编写可读代码的艺术
序.本书主要内容

简化命名、注释和格式的方法,使每行代码都言简意赅
梳理程序中的循环、逻辑和变量来减小复杂度并清理思路
在函数级别解决问题,例如重新组织代码块,使其一次只做一件事
编写有效的测试代码 ,使其全面而简洁,同时可读性更高



第一章 代码应当易于理解

1.可读性基本定理

关键思想:代码的写法应当使别人理解它所需的时间最小化。


2.代码总是越少越好吗

在这里插入图片描述


第一部分 表面层次的改进

在这里插入图片描述


第二章 把信息装到名字里

无论是命名变量、函数还是类,都可以使用很多相同的原则。我们喜欢把名字当做一条小小的注释。尽管空间不大,但选择一个好名字可以让它承载很多信息。



关键思想
把信息装入名字中


我们在程序中见到的很多名字都很模糊,例如tmp。就算是看上去合理的词,如size或者get,也都没有装入很多信息。本章会告诉你如何把信息装到名字中。
本章分成6个专题


  • 选择专业的词
  • 避免泛化的名字(或者说要知道什么时候使用它)
  • 用具体的名字代替抽象的名字
  • 使用前缀或者后缀给名字附带更多信息
  • 决定名字的长度
  • 利用名字的格式来表达含义

2.1 选择专业的词

“把信息装入名字中”包括要选择非常专业的词,并且避免使用“空洞”的词。
在这里插入图片描述
在这里插入图片描述


2.2 避免像tmp和retval这样泛泛的名字

在这里插入图片描述


2.3 用具体的名字代替抽象的名字

在这里插入图片描述


2.4 为名字附带更多信息

在这里插入图片描述


2.5 总结

在这里插入图片描述


第三章 不会误解的名字

关键思想:
要多问自己几遍:“这个名字会被别人解读成其他的含义吗?”要仔细审视这个名字。


在这里插入图片描述


3.1 推荐使用min和max来表示(包含)极限

在这里插入图片描述

MAX_ITEMS_IN_CART = 10;
MAX_C0MMODITY_IN_CART = 10;
private static final Integer MAX_ITEMS_IN_CART = 10;

3.2 推荐用first和last来表示包含的范围

在这里插入图片描述


3.3 推荐用begin和end来表示包含/排除范围


3.4 给布尔值命名



当为布尔变量或者返回布尔值的函数选择名字时,要确保返回true和false的意义明确


在这里插入图片描述



使用 is、has 、can 或 should 这样的词,可以把布尔值变得更加明确
最后,最好避免使用反义名字,例如 不要用:
bool disable_ssl = false;
而使用
bool use_ssl = true;



3.5 与使用者的期望相匹配



有些名字之所以会让人误解是因为用户对它们的含义有先入为主的印象,就算你的本意并非如此。在这种情况下,最好放弃这个名字而改用一个不会让人误解的名字。


在这里插入图片描述


3.6 总结



不会误解的名字是最好的名字,阅读你代码的人应该理解你的本意,并且不会有其他的理解。遗憾的是很多英语单词在用来编程的时候是多义性的,如filter、length和limit
在决定使用一个名字前要吹毛求疵一点,想象一下这个名字是否会被误解为其他意思。



第四章 审美

  1. 使用一致的布局,让读者很快就习惯这种风格
  2. 让相似的代码看上去相似
  3. 把相关的代码分组,形成代码块
    在这里插入图片描述


4.1 为什么代码审美这么重要

在这里插入图片描述


4.2 重新安排换行来保持一致和紧凑

把重复的功能/方法抽取出来单独形成一个方法。


4.3 在需要时使用列对齐在这里插入图片描述


4.4 选一个有意义的顺序,始终一致地使用它

在这里插入图片描述
在这里插入图片描述


4.5 把声明按块组织起来

在这里插入图片描述


4.6 把代码分成“段落”

在这里插入图片描述


4.7个人风格与一致性



一致的风格比“正确”的风格更重要



4.8 总结

在这里插入图片描述


第五章 该写什么样的注释

关键思想
注释的目的是尽量帮助读者了解得和作者一样多



5.1 什么不需要注释

不要为那些从代码本身就能快速推断的事实写注释


5.2 不要为了注释而注释


5.3 不要给不好的名字加注释–应该把名字改好



好代码>坏代码+好注释



5.4 记录你的思想

在这里插入图片描述


5.5 加入“导演评论”

在这里插入图片描述


5.6 为代码中的瑕疵写注释

代码始终在演进,并且在这个过程中肯定有瑕疵。不要不好意思把这些瑕疵记录下来。
例如,当代码需要改进时:
// TODO: 采用更快算法
或者当代码没有完成时:
// TODO(dustin):处理除JPEG以外的图像格式
在这里插入图片描述


5.7 给常量加注释



/** 排期编号自增加key */
private final static String SCHEDULE_SN = “learning:course:course_schedule_code”;



5.8 公布可能得陷阱

当为一个函数或者类写文档的时,可以问自己这样的问题,“这段代码有什么出人意料的地方?会不会被误用?”基本就是说你需要“未雨绸缪”,预料到别人使用你的代码有什么问题。
在这里插入图片描述


5.9 总结

在这里插入图片描述


第六章 写出言简意赅的注释

核心思想
注释应该有很高的信息/空间率



6.1 让注释更加紧凑

在这里插入图片描述


6.2 避免使用不明确的代词


6.3 精确地描述函数的行为


6.4 声明代码的意图


6.5 采用信息含量高的词

在这里插入图片描述


6.6 总结

在这里插入图片描述


第七章 把控制流变得易读

把条件、循环以及其他对控制流的改变做的越“自然”越好。运用一种方式使读者不用停下来重读你的代码



7.1 条件参数中参数的顺序

在这里插入图片描述
在这里插入图片描述


7.2 if/else语句块的顺序

在这里插入图片描述


第八章 拆分超长的表达式



把你超长的表达式拆分成更容易理解的小块



8.1 用做解释的变量

在这里插入图片描述


8.2 总结变量

在这里插入图片描述


8.3 使用摩根定理

在这里插入图片描述


8.4 滥用短路逻辑

// TODO


附录

1.链接: https://pan.baidu.com/s/1SHlVgqAEgnlj_kP_67U3rw?pwd=oin4 提取码: oin4







推荐阅读
  • 本文介绍了iOS数据库Sqlite的SQL语句分类和常见约束关键字。SQL语句分为DDL、DML和DQL三种类型,其中DDL语句用于定义、删除和修改数据表,关键字包括create、drop和alter。常见约束关键字包括if not exists、if exists、primary key、autoincrement、not null和default。此外,还介绍了常见的数据库数据类型,包括integer、text和real。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • 开发笔记:Java是如何读取和写入浏览器Cookies的
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Java是如何读取和写入浏览器Cookies的相关的知识,希望对你有一定的参考价值。首先我 ... [详细]
  • 第四章高阶函数(参数传递、高阶函数、lambda表达式)(python进阶)的讲解和应用
    本文主要讲解了第四章高阶函数(参数传递、高阶函数、lambda表达式)的相关知识,包括函数参数传递机制和赋值机制、引用传递的概念和应用、默认参数的定义和使用等内容。同时介绍了高阶函数和lambda表达式的概念,并给出了一些实例代码进行演示。对于想要进一步提升python编程能力的读者来说,本文将是一个不错的学习资料。 ... [详细]
  • Android系统源码分析Zygote和SystemServer启动过程详解
    本文详细解析了Android系统源码中Zygote和SystemServer的启动过程。首先介绍了系统framework层启动的内容,帮助理解四大组件的启动和管理过程。接着介绍了AMS、PMS等系统服务的作用和调用方式。然后详细分析了Zygote的启动过程,解释了Zygote在Android启动过程中的决定作用。最后通过时序图展示了整个过程。 ... [详细]
  • 本文介绍了Java中Hashtable的clear()方法,该方法用于清除和移除指定Hashtable中的所有键。通过示例程序演示了clear()方法的使用。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • JVM 学习总结(三)——对象存活判定算法的两种实现
    本文介绍了垃圾收集器在回收堆内存前确定对象存活的两种算法:引用计数算法和可达性分析算法。引用计数算法通过计数器判定对象是否存活,虽然简单高效,但无法解决循环引用的问题;可达性分析算法通过判断对象是否可达来确定存活对象,是主流的Java虚拟机内存管理算法。 ... [详细]
  • Java中包装类的设计原因以及操作方法
    本文主要介绍了Java中设计包装类的原因以及操作方法。在Java中,除了对象类型,还有八大基本类型,为了将基本类型转换成对象,Java引入了包装类。文章通过介绍包装类的定义和实现,解答了为什么需要包装类的问题,并提供了简单易用的操作方法。通过本文的学习,读者可以更好地理解和应用Java中的包装类。 ... [详细]
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • JDK源码学习之HashTable(附带面试题)的学习笔记
    本文介绍了JDK源码学习之HashTable(附带面试题)的学习笔记,包括HashTable的定义、数据类型、与HashMap的关系和区别。文章提供了干货,并附带了其他相关主题的学习笔记。 ... [详细]
  • 欢乐的票圈重构之旅——RecyclerView的头尾布局增加
    项目重构的Git地址:https:github.comrazerdpFriendCircletreemain-dev项目同步更新的文集:http:www.jianshu.comno ... [详细]
  • 基于Socket的多个客户端之间的聊天功能实现方法
    本文介绍了基于Socket的多个客户端之间实现聊天功能的方法,包括服务器端的实现和客户端的实现。服务器端通过每个用户的输出流向特定用户发送消息,而客户端通过输入流接收消息。同时,还介绍了相关的实体类和Socket的基本概念。 ... [详细]
author-avatar
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有