API ( IPA : [ ˌ e ɪ . p i ˈ a ɪ ]; förkortning från engelska. Application Programming Interface [ 1 ] ) är en beskrivning av hur ett datorprogram interagerar med andra. Vanligtvis inkluderat i beskrivningen av något Internetprotokoll (till exempel SCIM [2] ), mjukvaruramverk ( ramverk [3] ) eller operativsystems funktionsanropsstandard [4] . Implementeras ofta av ett separat mjukvarubibliotekeller en operativsystemtjänst . Används av programmerare när de skriver alla typer av applikationer .
Enkelt uttryckt är detta en uppsättning komponenter som ett datorprogram (bot eller webbplats) kan använda ett annat program med.
Ett API (Application Programming Interface) förenklar programmeringsprocessen när man bygger applikationer genom att abstrahera bort den underliggande implementeringen och tillhandahålla endast de objekt eller åtgärder som utvecklaren behöver. Om ett GUI för en e-postklient kan förse användaren med en knapp som går igenom alla steg för att hämta och markera nya e-postmeddelanden, så kan File I/O API ge utvecklaren en funktion som kopierar en fil från en plats till en annan utan att kräva att utvecklaren förstår filoperationer.system som pågår bakom kulisserna. [5]
Om ett program (modul, bibliotek) betraktas som en svart låda , är API:et en uppsättning "handtag" som är tillgängliga för användaren av denna låda och som han kan vända och dra.
Programvarukomponenter interagerar med varandra genom API:er. I det här fallet bildar komponenter vanligtvis en hierarki - komponenter på hög nivå använder API för komponenter på låg nivå, och de använder i sin tur API för komponenter på lägre nivå.
Enligt denna princip byggs dataöverföringsprotokoll över Internet . Standardprotokollstacken ( OSI-nätverksmodell ) innehåller 7 lager (från det fysiska bitöverföringslagret till applikationsprotokolllagret som HTTP och IMAP ). Varje lager använder funktionaliteten för det föregående (”nedre”) dataöverföringslagret och ger i sin tur den önskade funktionaliteten till nästa (”övre”) lager.
Konceptet med ett protokoll ligger nära begreppet API. Båda är abstraktioner av funktionalitet, bara i det första fallet talar vi om dataöverföring och i det andra - om interaktionen mellan applikationer.
Funktions- och klassbibliotekets API innehåller en beskrivning av funktioners signaturer och semantik .
En funktionssignatur är en del av en allmän funktionsdeklaration som gör det möjligt för översättare att bland annat identifiera funktionen. Olika programmeringsspråk har olika idéer om signaturen för en funktion, vilket också är nära relaterat till möjligheterna till funktionsöverbelastning i dessa språk.
Ibland görs skillnad mellan en anropssignatur och en funktionsimplementeringssignatur . Anropssignaturen kompileras vanligtvis enligt den syntaktiska konstruktionen av ett funktionsanrop, med hänsyn tagen till signaturen för denna funktions omfattning, namnet på funktionen, sekvensen av faktiska typer av argument i anropet och typen av resultat. Implementeringssignaturen innefattar vanligtvis några element från den syntaktiska konstruktionen av funktionsdeklarationen: funktionsomfångsspecifikatorn, dess namn och sekvensen av formella argumenttyper.
Till exempel, i programmeringsspråket C++ , identifieras en enkel funktion unikt av kompilatorn genom dess namn och sekvensen av dess argumenttyper, som utgör funktionssignaturen på det språket. Om funktionen är en metod för någon klass, kommer klassnamnet också att delta i signaturen.
I programmeringsspråket Java är signaturen för en metod dess namn och sekvensen av parametertyper; typen av det returnerade värdet är inte inblandat i signaturen. [6]
En funktions semantik är en beskrivning av vad en given funktion gör. En funktions semantik innehåller en beskrivning av vad som är resultatet av utvärderingen av funktionen, hur och på vad detta resultat beror på. Vanligtvis beror exekveringsresultatet endast på värdena för funktionsargumenten, men i vissa moduler finns ett tillståndsbegrepp. Då kan resultatet av funktionen bero på detta tillstånd, och dessutom kan resultatet bli en tillståndsändring. Logiken bakom dessa beroenden och förändringar är relaterad till funktionens semantik. En fullständig beskrivning av funktioners semantik är den körbara koden för funktionen eller den matematiska definitionen av funktionen.
Nästan alla operativsystem ( UNIX , Windows , OS X , Linux etc.) har ett API med vilket programmerare kan skapa applikationer för det operativsystemet. Operativsystems huvudsakliga API är en uppsättning systemanrop .
Inom mjukvaruindustrin spelar gemensamma standard-API:er för standardfunktionalitet en viktig roll, eftersom de säkerställer att alla program som använder ett gemensamt API kommer att fungera lika bra, eller åtminstone på ett typiskt bekant sätt. När det gäller GUI API:er betyder detta att program kommer att ha ett liknande användargränssnitt, vilket gör det lättare att lära sig nya mjukvaruprodukter.
Å andra sidan gör skillnader i API:er för olika operativsystem det mycket svårt att portera applikationer mellan plattformar. Det finns olika metoder för att komma runt denna komplexitet - att skriva "mellanliggande" API:er (API för grafiska gränssnitt wxWidgets , GTK , etc.), skriva bibliotek som mappar systemanrop från ett OS till systemanrop från ett annat OS (runtime-miljöer som Wine , cygwin och etc.), införa kodningsstandarder i programmeringsspråk (till exempel C -standardbiblioteket ), skriva tolkade språk som kan implementeras på olika plattformar ( sh , Python , Perl , PHP , Tcl , Javascript , Ruby , etc.).
Dessutom har en programmerare ofta flera olika API:er till sitt förfogande för att uppnå samma resultat. I det här fallet implementeras varje API vanligtvis med hjälp av API:er för programvarukomponenter med en lägre abstraktionsnivå.
Till exempel: för att se raden " Hej världen!" ”, behöver du bara skapa ett HTML- dokument med en minimal titel och en enkel text som innehåller den givna strängen. När webbläsaren öppnar det här dokumentet skickar webbläsarprogrammet filnamnet (eller en redan öppen filbeskrivning ) till biblioteket som bearbetar HTML-dokument, som i sin tur, med hjälp av operativsystemets API, kommer att läsa denna fil och förstå dess enhet , sedan sekventiellt anropa genom API för biblioteket av standard grafiska primitiver för operationer som "rensa fönstret", "skriv "Hej, värld!" i det valda teckensnittet. Under utförandet av dessa operationer kommer det grafiska primitiva biblioteket att vända sig till fönstergränssnittsbiblioteket med lämpliga förfrågningar, detta bibliotek kommer redan att vända sig till operativsystemets API för att skriva data till grafikkortets buffert .
Samtidigt finns det faktiskt flera möjliga alternativa API:er på nästan alla nivåer. Till exempel: vi skulle kunna skriva källdokumentet inte i HTML, utan i LaTeX , vi kan använda vilken webbläsare som helst för visning. Dessutom använder olika webbläsare olika HTML-bibliotek, och dessutom kan allt detta byggas med olika primitiva bibliotek och på olika operativsystem.
Huvudkomplexiteten hos befintliga skiktade API-system är således:
|
Används i webbutveckling - den innehåller vanligtvis en viss uppsättning HTTP- förfrågningar, såväl som en definition av strukturen för HTTP-svar, för vars uttryck de använder XML- eller JSON -format .
Webb-API är nästan synonymt med en webbtjänst, även om den senaste Web 2.0- trenden har skiftat från SOAP- till REST- kommunikation. Webbgränssnitt som tillhandahåller en kombination av flera tjänster i nya applikationer kallas mashups.
Exempel: MediaWiki API
av operativsystem | Aspekter|||||
---|---|---|---|---|---|
| |||||
Typer |
| ||||
Kärna |
| ||||
Processledning _ |
| ||||
Minneshantering och adressering | |||||
Ladda och initieringsverktyg | |||||
skal | |||||
Övrig | |||||
Kategori Wikimedia Commons Wikibooks Wiktionary |