在本月初的 GopherCon 上,知名 Go 语言贡献者与布道师 Dave Cheney 发表了名为《The Zen of Go》的演讲,之后他整理了演讲内容在博客中分享,由于内容过长,他又写了一个简洁版本:

完整版:

https://dave.cheney.net/2020/02/23/the-zen-of-go


简洁版:

https://the-zen-of-go.netlify.com

这里简单翻译一下简洁版本的内容:

编写简单、可读、可维护的 Go 代码的十个工程要点。

每个包实现单一目标

设计良好的 Go 软件包提供一个单一的思路,以及一系列相关的行为。一个好的 Go 软件包首先需要选择一个好名字,使用电梯法则(30 秒内向客户讲清楚一个方案),仅用一个词来思考你的软件包要提供什么功能。

明确处理错误

健壮的程序其实是由处理故障案例的片段组成的,并且需要在故障出现之前处理好。冗余的if err != nil { return err }比出了故障再一个个去处理更有价值。panic 和 recover 也一样。

尽早 return,不要深陷

每次缩进时都会在程序员的堆栈中添加另一个先决条件,这会占用他们短期内存中的 7±2 个片段。避免需要深层缩进的控制流。与其深入嵌套,不如使用守卫子句将成功路径保持在左侧。

并发权留给调用者

让调用者选择是否要异步运行你的库或函数,不要强制他们使用异步。

在启动 goroutine 之前,要知道它什么时候会停止

goroutines 拥有资源、锁、变量与内存等,释放这些资源的可靠方法是停止 goroutine。

避免包级别的状态

要完成明确和减少耦合的操作,需要通过提供类型需要的依赖项作为该类型上的字段,而不是使用包变量。

简单很重要

简单不是老练的代名词。简单并不意味着粗糙,它意味着可读性和可维护性。如果可以选择,请遵循较简单的解决方案。

编写测试以确认包 API 的行为

软件包的 API 是与使用者的一份合约,不管先后,不管多少,一定要进行测试。测试是确定合约的保证。要确保测试使用者可以观察和依赖的行为。

如果你认为性能不行,先通过基准测试进行验证

以性能之名会犯下许多危害可维护性的罪行。优化会破坏抽象、暴露内部和紧密耦合。如果要付出这样的代价,请确保有充分理由这样做。

节制是一种美德

适度使用 goroutine、通道、锁、接口与嵌套。

©著作权归作者所有:来自51CTO博客作者mob604756fb8908的原创作品,如需转载,请注明出处,否则将追究法律责任

更多相关文章

  1. winget install,微软开源Windows软件包管理器
  2. 【OS】什么是YUM?如何配置本地YUM源?
  3. Linux编程 18 安装软件程序(yum工具对软件包安装,删除,更新介绍)
  4. 20210221-2 软件管理与网络管理
  5. Linux软件管理——yum rpm工具使用【CentOS】
  6. Linux运维入门教程08-01 (Linux软件包的管理)
  7. 利用 npm 的缺陷,他获得了 130,000 美元的赏金
  8. zabbix yum及package模块
  9. 软件包管理

随机推荐

  1. android如何处理不同屏幕的适配
  2. js判断访问浏览器是安卓还是ios还是微信
  3. mono修改代码模板
  4. Android API指南(二)自定义控件04之 位置
  5. Android的RelativeLayOut中各种属性的作
  6. Android(安卓)RingtoneManager铃声管理
  7. Android 使用html做UI的方法---js与java
  8. 应用界面主题Theme使用方法
  9. 用Eclipse开发Android应用程序(3): 开发
  10. Android连接Mysql数据库教程以及增删改查