什么是API,不同场景中的API

电子说

1.3w人已加入

描述

API(Application Programming Interface)有点类似于肯德基汽车穿梭窗口。但在代码中,它们接受输入并提供可预测的输出。  

在其核心,API是一组接受输入并给出输出的代码

大多数现代应用程序(如Excel)都是一堆API组成的

有时,公司会公开他们的部分API,比如Twitter或谷歌地图

API是软件中比较令人困惑的概念之一,因为它们可以代表很多不同的东西

API为大多数现代软件开发提供了强大的功能,且是可以聪明地讨论代码的关键部分。  

什么是API(理论上)?

如果你想理解API,需要进行一个重要的区分:一个是API的技术定义,然后是人们在对话中如何实际使用这个概念。它们非常不同,这就是为什么这些东西会让人很困惑。让我们先来解决技术定义。  

API

API是一组接受特定输入并给出特定输出的逻辑。几个例子:

如果向谷歌地图API提供一个地址作为输入,它的输出是该地址的经纬度坐标

如果给Javascript Array.Sort API一个数组作为输入,它将这些数字作为输出进行排序

如果你给Lyft Driver API一个起始地址和结束地址作为输入,它会找到最匹配的司机作为输出

当工程师构建代码模块来做特定的事情时,他们清楚地定义了这些模块的输入和输出:这就是API的真正含义。当你给一个API一堆输入来获得你想要的输出时,它被称为调用API。   输入 API通常会确切地告诉你它需要什么样的输入。如果你尝试用你的名字作为谷歌地图API的输入,那不会有什么效果;它被设计用来完成一个非常特定的任务(将地址转换为坐标),因此它只处理非常特定类型的数据。有些API在输入方面非常麻烦,并可能要求你以特定的方式格式化该地址。   输出 就像输入一样,API给你特定的输出。假设你为谷歌地图API提供了正确的输入(一个地址),它将始终以完全相同的格式给你回馈坐标。还有非常具体的错误处理:如果API不能找到你输入的地址的坐标,它会告诉你确切的原因。   这些都是技术和理论上的东西。   那些应用只是API的集合 关于现代软件,最值得理解的一点是,你最喜欢的那些应用只是一堆API,上面有一个漂亮的界面,称为前端。你使用的大多数应用都是建立在这种前端/后端范例之上的。   后端 公司从为用户在应用中需要做的所有重要事情构建API开始。对于Gmail,Google从接收、显示、发送和转发邮件的API开始;但这些都是通过代码调用的。这些API以及使用它们的时间和方式的逻辑是应用的后端。就像汽车引擎盖下正在发生的事。如果你听说过后端工程师,那就是主要处理这些内部组件的开发者。   前端 所有这些后端API只能通过代码来使用,这并不是你想在iPhone上查看电子邮件时遇到的情况。这就是为什么公司要为他们的应用创建前端:图形用户界面使应用美观且可用,而不需要编写代码。下面是Gmail中的工作方式:

你的收件箱显示一排排的电子邮件和主题行:前端将这些后端的电子邮件数据进行了很好的格式化处理

你可以点击星形图标来标记一封邮件:在后端,这将触发一个“标记邮件”的API

前端的大多数交互都被转换成后端的API调用,这就是应用软件101。一旦我开始理解这个模型,就更容易理解开发者如何在对话中实际使用“API”的方式了。  

API

什么是API(实际上)?

实际上,我发现人们在三种不同的场景中使用“API”,它们都代表着不同的东西。但从理论上讲,它们都是一样的,符合我们之前的定义。它们都是一样的,但又有所不同。

公司内部API

当公司构建他们的应用时,他们把它们设计成一组交互的API。最容易理解的例子是Lyft(或者Uber)。你可能想在Lyft应用中做一些事情,它们在幕后都会触发不同的API。

API

这种模式几乎适用于你使用的所有应用:你在应用中采取的操作将触发公司内部API,这些API实际上完成了让你的请求得到满足的工作。公司内部API也是分层的:虽然可能有一个广泛的“预约乘车”API,但在这个“引擎盖”下有一堆较小的API来完成它:查找司机、预约司机、验证信用卡、与用户沟通等。

公共API

Lyft的API都不是公开的:它们只是Lyft在后端为你提供服务的方式。但有时,公司会提供一些他们的API,并告诉你如何使用它们。Twitter的API就是一个很好的例子。

通常,你使用Twitter应用,它会对Twitter内部API进行一些API调用,比如显示提要、发送回复和搜索(这就是我们刚刚谈到的:前端和后端)。但你也可以在Twitter应用之外通过代码调用这些API。例如,有一个抓取用户时间轴的API,你可以使用它来查看用户的时间轴(他们的推文),该API以JSON格式返回那些推文,这是一种特殊的文本格式。

这些公共API让人们在Twitter上构建应用。有一些非常基本的东西,比如笔者做的这个学校项目,收集关于纽约大学的推文,分析他们的情绪,但也有一些相当高级的东西,比如Flock,它可以让你搜索你的订阅者。

代码接口

我们刚刚看到的前两类API都是功能性的,它们通常完成一些实用且容易理解的事情,比如提供坐标或预订乘车。但是开发者也使用“API”来指代更底层级别的输入和输出,比如代码中的函数。

Javascript的array.sort()方法就是一个很好的例子。它是一个接受数字或字母列表作为输入的API,然后对它们进行排序,并将它们作为输出返回给你。还有其他与数组相关的API,比如添加(array.push)和移除(array.pop)东西,过滤(array.filter),以及获取数组的大小(array.length)。当你用Javascript的时候,你会用到这些。

因此,当人们谈论API时,我们并不总是清楚人们到底在谈论什么,特别是因为开发者用这个词指代很多不同的东西。如果你感到困惑,就直接问。答案很可能属于这三类。

API

编辑:黄飞

 

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 相关推荐
  • API

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分