講個小故事:研發人員A開發了軟件A,研發人員B正在研發軟件B。 有一天,研發人員B想要調用軟件A的部分功能來用,但是他又不想從頭看一遍軟件A的源碼和功能實現過程,怎么辦呢? 研發人員A想了一個好主意:我把軟件A里你需要的功能打包好,寫成一個函數。你按照我說的流程,把這個函數放在軟件B里,就能直接用我的功能了!其中,API就是研發人員A說的那個函數。
日常生活中,我們有很多類似API的場景,比如:
電腦需要調用手機里面的信息,這時候你會拿一根數據線將電腦手機連接起來,電腦和手機上連接數據線的接口就相當於“API接口”。如圖所示:
那SDK又是什么?
SDK 就是 Software Development Kit 的縮寫,翻譯過來——軟件開發工具包。這是一個覆蓋面相當廣泛的名詞,可以這么說:輔助開發某一類軟件的相關文檔、范例和工具的集合都可以叫做SDK。SDK被開發出來是為了減少程序員工作量的。
比如——有公司開發出某種軟件的某一功能,把它封裝成SDK(比如數據分析SDK就是能夠實現數據分析功能的SDK),出售給其他公司做開發用,其他公司如果想要給軟件開發出某種功能,但又不想從頭開始搞開發,直接付錢省事。
現在可以談談API和SDK的區別了。
總的來說,兩者沒有值得比較的區別,因為是具有關聯性的兩種東西。你可以把SDK想象成一個虛擬的程序包,在這個程序包中有一份做好的軟件功能,這份程序包幾乎是全封閉的,只有一個小小接口可以聯通外界,這個接口就是API。比如——我們現在要在企業ERP系統中增加某個功能(比如自動備份、數據分析、雲存儲等),但又不想耗費大量時間、也沒那么多研發親自去做這個功能。這時我們可以選擇使用這個“SDK”軟件包,把ERP系統連接上API接口,就可以使用SDK軟件包里的功能。
最后,貼近生活講講兩者的關系:
有一杯密封飲料,它的名字叫做“SDK”。飲料上插着吸管,吸管的名字叫“API”。把你叫做“XX系統”。如果你想喝到SDK里的飲料(讓系統擁有SDK中的功能),你必須通過API這根吸管來實現(通過API連接你的系統和SDK工具包),否則你就喝不到飲料。所以:SDK=放着你想要的軟件功能的軟件包API=SDK上唯一的接口
SDK 是可以下載的。API 是寫在文檔里的。
作者:簡道雲
鏈接:https://www.zhihu.com/question/21691705/answer/770586138
來源:知乎
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。