API: Difference between revisions
Frecklefoot (talk | contribs) →API examples: merge Java APIs |
No edit summary |
||
Line 1: | Line 1: | ||
{{redirect|API}} |
{{redirect|API}}-- |
||
An '''application programming interface''' ('''API''') is a set of declarations of the functions (or procedures) that an [[operating system]], [[library (computer science)|library]] or [[Service (systems architecture)| service]] provides to support requests made by [[computer program]]s.<ref>{{cite web| |
An '''application programming interface''' ('''API''') is a set of declarations of the functions (or procedures) that an [[operating system]], [[library (computer science)|library]] or [[Service (systems architecture)| service]] provides to support requests made by [[computer program]]s.<ref>{{cite web| |
||
url=http://www.computerworld.com/action/article.do?command=viewArticleBasic&articleId=43487| |
url=http://www.computerworld.com/action/article.do?command=viewArticleBasic&articleId=43487| |
Revision as of 18:08, 29 July 2008
--
An application programming interface (API) is a set of declarations of the functions (or procedures) that an operating system, library or service provides to support requests made by computer programs.[1]
- Language-dependent APIs are available only in a particular programming language. They utilize the syntax and elements of the programming language to make the API convenient to use in this particular context.
- Language-independent APIs are written in a way that means they can be called from several programming languages. This is a desired feature for a service-style API which is not bound to a particular process or system and is available as a remote procedure call.
API versus ABI
An API is typically defined at a higher level (i.e., in terms of a programming language that can be compiled when an application is built, rather than an explicit low level description of how data is laid out in memory). For example, the Linux Standard Base is an ABI (Application Binary Interface), while POSIX is an API.[2]
Distinction between specification and its implementation
The software that provides the functionality described by an API is said to be an implementation of the API. The API itself is abstract, in that it specifies an interface and the behavior of the identifiers specified in that interface; it does not specify how the behavior may be implemented.
Release policies
There are two general kinds of API publishing policies that are often encountered:
- Some companies protect information on their APIs from the general public. For example, Sony used to make its official PlayStation 2 API available only to licensed PlayStation developers. This enabled Sony to control who wrote PlayStation 2 games. Such control can have quality control benefits and potential license revenue.
- Some companies make their APIs freely available. For example, Microsoft makes the Microsoft Windows API public and Apple releases its APIs Carbon and Cocoa so that software can be written for their platform.
API examples
Below are listed some well-known APIs.
- The PC BIOS call interface
- Comedi Data Acquisition API
- Single UNIX Specification (SUS)
- Windows API
- The various Java Platform Edition APIs (Micro, Standard, Enterprise)
- ASPI for SCSI device interfacing
- Carbon and Cocoa for the Macintosh OS
- iPhone API
- OpenGL cross-platform 3D graphics API
- DirectX for Microsoft Windows
- Simple DirectMedia Layer (SDL)
- Google Maps API
- MediaWiki API
- YouTube API
- PayPal Payment Pro
Language bindings and interface generators
Below are listed some interface generator tools.
- SWIG generates interfaces from various languages for Python
- F2PY: Fortran to Python interface generator.
See also
- Application Binary Interface (ABI)
- Document Object Model (DOM)
- Mashup (web application hybrid)
- Open Service Interface Definitions (OSID)
- Plugin
- Software Development Kit (SDK)
- Web service
- List of 3D graphics APIs
References
- ^ "QuickStudy: Application Programming Interface (SAPI)". ComputerWorld.
- ^ "Update on Standards" (PDF). USENIX.
External links
- How to design a good API and why it matters-PDF
- The trends and the role of API-driven mashup building tools in the enterprise computing
- Service-Oriented Architecture (SOA): The Road to Enterprise Application Integration (EAI)
- Organized list of API references with fast as-you-type search
- ISO/IEC JTC 1 Directives, 5th Edition Version 3.0, Annex J: Guidelines for API standardization