Application programming interface
From Wikipedia, the free encyclopedia
An application programming interface (API) is a set of functions, procedures, methods or classes 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.
Contents |
[edit] 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]
[edit] 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.
[edit] Scope of the term in communications
The API acronym is often used in documentation, discussions or other communications in reference to all of the programming interfaces in the set, a single function in the set and sometimes multiple APIs provided by an organization. Thus the scope is usually determined by the person, entity or document that communicates the information.
[edit] 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.
[edit] 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
- Facebook API
- Drupal API (Drupal)
[edit] 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.
[edit] 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
[edit] References
- ^ "QuickStudy: Application Programming Interface (API)". ComputerWorld.
- ^ "Update on Standards". USENIX.
[edit] 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