【前沿技术】API设计原则

简介: 【前沿技术】API设计原则

1 引言

优秀的 API 之于代码,就如良好内涵对于每个人。好的 API 不但利于使用者理解,开发时也会事半功倍,后期维护更是顺风顺水。

一个骨灰级资深的同事跟我说过,任何在成长的代码库,至少半年到一年就要重构一次,否则失去的不仅是活力,更失去了可维护性与可用性。

2 内容概要

由于本文已经是翻译后的文章,概要只列出不涉及 c++ 概念的思路框架,细节请移步译文

好 API 的 6 个特质

极简且完备、语义清晰简单、符合直觉、易于记忆和引导 API 使用者写出可读代码。

静态多态

尽量减少继承,让相似的类具备相似的 API,而不是统一继承一个父类。因为统一继承会带来 API public 数量过多,父级无意义的方法对用户产生误导。

基于属性的 API

属性指的是对象状态,通过属性为粒度的 API,有利于使用者理解 API 的含义,但需注意关联属性的顺序性。

API 语义和文档

比如传值 -1 的含义是什么?如果 API 文档不像 http status codes 一样健全,建议通过枚举的方式增加可读性。

命名的艺术

不要使用缩写,保持一致性。类命名以功能分组作为后缀,比零散命名更易懂。

函数命名要体现出是否包含副作用,参数过多时以对象作为传参,布尔参数改为枚举类型,或者分解为两个语义化 API。

3 精读

以下精读是对原文观点的补充。

Const 入参

eslint 有一条规则,不要直接改变入参的值。这个规则的初衷是解决函数副作用问题,禁止可能产生副作用代码的产生。但却可以通过如下方式避免:

1. function (num) {
2.   let scopeNum = num
3.   scopeNum = 5
4. }

这是从包含指针类型编程语言学习过来的,因为当 表示指针时,代表代码可能产生副作用(修改入参的风险)。而 js 并不总是这样的,不但没有指针申明,基本类型也总是通过拷贝进入传参,非基本类型通过引用传递,也就是会发生通过如上代码绕过检测,却依然产生副作用(改变函数入参)的情况。*num

为了避免副作用,建议引入 或 ,通过 关键字与约定约束入参行为:flowtypescriptconst

1. function (const num) {
2.   ...
3. }

将没有副作用函数的所有入参定义为 类型,静态检查阶段就禁止了对值的直接修改,同时因为有这个关键字的约束,在函数体内也约定不要通过引用浅拷贝修改它的值。const

但这也无法彻底避免,仍然可以通过如下写法绕过检测,修改入参:

1. function (const num) {
2. const scopeNum = { ...num }
3.   scopeNum.a.b = 'c'
4. }

在 js 中没有完美的方式避免对入参的修改,但通过对入参修饰 关键字,可以对使用者明确这是纯函数,对开发者提示不要写有副作用的代码。const

c++ 的 定义从编译开始就完全杜绝了修改的可能性,虽然有 “去” 行为,但仍然不会改变入参的值(虽然可以后续对值修改,指针指向保持不变,但用 修饰的入参值永远不会改变)。constconst_castconstconst

统一关键字库

所有 api 定义之前,先抽离业务和功能语义的关键字,统一关键字库; 可以更好的让多人协作看起来如出一辙, 而且关键字库 更能够让调用者感觉到 符合直觉、语义清晰; 关键字库也是项目组新同学 PREDO 的内容之一, 很有带入感;

单一职责

接口设计尽量要做到 单一职责,最细粒度化; 可以使用组合的方式把多个解耦的单个接口组合在一起作为一个大的功能项接口; 接口设计的单一职责,也更方便多人协作时候的扩展和组合;

面向未来的多态

对于接口参数的扩展,我们要做到面向扩展开放,面向修改关闭;升级做到要兼容,否则会导致大批量的下游不可用。

同时也要避免过度设计,当抽象功能只有一处使用时,尽量不要过早抽象。

不要重复局部命名

1. class User {
2. // good
3. setName() {}
4. 
5. // bad
6. setUserName() {}

}

在有上下文环境的调用中,减少不必要的描述可以提高 API 的精简和清晰度。

同时要避免过度使用解构,因为解构会丢失上下文,让我们对变量来源一无所知:

1. const { setName } = this.props.store.user
2. const { setVisible } = this.props.store.article

 

上述 脱离了 作用域,当隔着几百行调用时,早已不知所云。setNamesetVisibleuserarticle

4 总结

参考优秀类库是设计 API 很好的方法之一,比如本文 c++ 参考的 Qt、js 可以参考 jQuery。

当 API 稳定后,需要花时间整理文档,因为写文档的思考过程可能推动着你重构和优化代码。

最后,如果有精力,最好每半年重构一次(然后完整跑一遍测试)!

相关文章
|
2月前
|
IDE Java API
使用Java Web技术构建RESTful API的实践指南
使用Java Web技术构建RESTful API的实践指南
|
3月前
|
数据采集 传感器 人工智能
大数据关键技术之电商API接口接入数据采集发展趋势
本文从数据采集场景、数据采集系统、数据采集技术方面阐述数据采集的发展趋势。 01 数据采集场景的发展趋势 作为大数据和人工智能工程的源头,数据采集的场景伴随着应用场景的发展而变化,以下是数据采集场景的发展趋势。
|
4月前
|
Java Shell 分布式数据库
【大数据技术Hadoop+Spark】HBase数据模型、Shell操作、Java API示例程序讲解(附源码 超详细)
【大数据技术Hadoop+Spark】HBase数据模型、Shell操作、Java API示例程序讲解(附源码 超详细)
84 0
|
4月前
|
分布式计算 Java 大数据
【大数据技术Hadoop+Spark】HDFS Shell常用命令及HDFS Java API详解及实战(超详细 附源码)
【大数据技术Hadoop+Spark】HDFS Shell常用命令及HDFS Java API详解及实战(超详细 附源码)
221 0
|
1月前
|
API 开发者 UED
深入探讨RESTful API设计原则及最佳实践
在当今互联网时代,RESTful API已成为各种软件系统之间进行通信的重要方式。本文将从资源定义、URI设计、HTTP方法选择、状态码规范等方面深入探讨RESTful API设计的原则与最佳实践,帮助开发者更好地构建高效、健壮的API。
|
5月前
|
Java API Maven
微服务技术系列教程(27) - SpringCloud- Zuul整合Swagger管理微服务所有API
微服务技术系列教程(27) - SpringCloud- Zuul整合Swagger管理微服务所有API
56 0
|
2月前
|
API 开发者 UED
深入理解RESTful API设计原则
【2月更文挑战第9天】 传统的RESTful API设计原则在实际开发中并不是一成不变的,随着技术的发展和应用场景的变化,我们需要不断深入理解RESTful API的设计原则,并结合具体情况进行灵活应用,以更好地满足现代应用的需求。
29 4
|
3月前
|
存储 JSON API
淘宝/天猫商品详情实时数据API技术实现
随着电子商务的蓬勃发展,对于电商平台的商家而言,实时获取商品数据变得至关重要。通过API接口,可以轻松地从电商平台获取这些数据。本文将详细介绍如何使用淘宝/天猫提供的API接口实现商品详情数据的实时获取,并给出具体的代码示例。
|
4月前
|
监控 数据挖掘 API
阿里巴巴API接口技术揭秘:轻松驾驭电商数据,提升业务效率
阿里巴巴API接口技术揭秘:轻松驾驭电商数据,提升业务效率
|
9月前
|
文字识别 API 语音技术
百度语音技术:文字识别转化为语音在线API和PHP-SDK开发文档的学习
百度语音技术:文字识别转化为语音在线API和PHP-SDK开发文档的学习
65 0