什麽是好的API設計?

字號+ 編輯: 国内TP粉 修訂: 种花家 來源: ThinkPHP 2023-09-10 我要說兩句(3)

工作不飽和,才想到轉發這篇文章。

今天又来到了吹批面试过程的时间了, 先说说:

什么是API?

API简单来讲可以是一个调用的函数,一个接口。

我们只要是在进行编程我们就需要不停的设计API。

抽象来说,接口是一个内聚系统暴漏给外部的一切信息,包含但不限于:

调用方式

比如通过lib库或者http接口等。

调用约定

比如lib的函数签名或者HTTP的参数,http method或者头信息,长短链接等等。

依赖关系

比如接口的调用需要涉及到第三方或者其他的准备工作等等。

API就像一个人一样,我们和一个API打交道的时候需要了解这个人的特性偏好等,有的人很好相处,而有的人让人很头疼,尤其是你不得不和他打交道的时候,和人一样,如果你不得不和他打交道,要改变他的秉性是很痛苦的,人的“本性难移”, API也一样,一旦发布了,要改变的成本就很大很大。

好的API应该具有:

易于学习

即使没有文档也易于使用。

不易误用

这一点很重要,要减少使用者的心智负担。

易于满足需求

API的完备性和正交性。能够容易的满足需求,完备性保证功能完整,正交性保证接口的简洁性,不需要为所有的需求提供接口,而是由用户去组合。

易于扩展性

...

怎么样设计良好的API?

专一

一个API的功能应该是单一的,需要能够很容易的解释和理解,也就会更好用。

尽可能的小, 轻量级

小有很多的优势,易于理解和维护。

尽量少的外部依赖

减少使用者的成本。

设计不被实现影响

不要暴漏实现细节给用户,竟可能少的暴露,不止是内部细节,对于不必要的接口尽量不要发布,比如使用不多的功能,可以暂时不暴露接口。

良好的命名

尽量做到自描述。

完善的文档(特别是公司团队项目)

考虑性能(听起来像废话, 但没性能的接口咱好意思写出去给人用吗)

閲完此文,您的感想如何?
  • 有用

    0

  • 沒用

    1

  • 開心

    0

  • 憤怒

    0

  • 可憐

    0

1.如文章侵犯了您的版權,請發郵件通知本站,該文章將在24小時内刪除;
2.本站標注原創的文章,轉發時煩請注明來源;
3.交流群: 2702237 13835667

相關課文
  • mac開發接入微信公衆號接口返回報錯 cURL error 56: SSLRead() return error -9806

  • PHP的換行符是什麽

  • pecl安裝程序時報錯Array and string offset access syntax with curly braces is no longer supported

  • 由於商家傳入的H5交易參數有誤,該筆交易暫時無法完成,請聯繫商家解決

我要說說
網上賓友點評
1 樓 IP 106.50.***.27 的嘉賓 <i style="color:red;font-style:normal">怒</i>道 : 很久前
废话

2 樓 IP 111.192.***.152 的嘉賓 说道 : 很久前
又快又稳的就行了- -设计个屁啊

3 樓 IP 111.192.***.181 的嘉賓 说道 : 很久前
这都是国内那些java培训公司留下来的遗毒。