ANSI C
C language revisions |
---|
ANSI C, ISO C, and Standard C are successive standards for the C programming language published by the American National Standards Institute (ANSI) and ISO/IEC JTC 1/SC 22/WG 14 of the International Organization for Standardization (ISO) and the International Electrotechnical Commission (IEC). Historically, the names referred specifically to the original and best-supported version of the standard (known as C89 or C90). Software developers writing in C are encouraged to conform to the standards, as doing so helps portability between compilers.
History and outlook
[edit]The first standard for C was published by ANSI. Although this document was subsequently adopted by ISO/IEC and subsequent revisions published by ISO/IEC have been adopted by ANSI, "ANSI C" is still used to refer to the standard.[1] While some software developers use the term ISO C, others are standards-body neutral and use Standard C.
Informal specification: K&R C (C78)
[edit]Informal specification in 1978 (Brian Kernighan and Dennis Ritchie book The C Programming Language).
Standardizing C
[edit]In 1983, the American National Standards Institute formed a committee, X3J11, to establish a standard specification of C. In 1985, the first Standard Draft was released, sometimes referred to as C85. In 1986, another Draft Standard was released, sometimes referred to as C86. The prerelease Standard C was published in 1988, and sometimes referred to as C88.[2]
C89
[edit]The ANSI standard was completed in 1989 and ratified as ANSI X3.159-1989 "Programming Language C." This version of the language is often referred to as "ANSI C". Later on sometimes the label "C89" is used to distinguish it from C90 but using the same labeling method.
C90
[edit]The same standard as C89 was ratified by ISO/IEC as ISO/IEC 9899:1990, with only formatting changes,[3] which is sometimes referred to as C90. Therefore, the terms "C89" and "C90" refer to a language that is virtually identical.
This standard has been withdrawn by both ANSI/INCITS[4] and ISO/IEC.[5]
C95
[edit]In 1995, the ISO/IEC published an extension, called Amendment 1, for the C standard. Its full name finally was ISO/IEC 9899:1990/AMD1:1995 or nicknamed C95. Aside from error correction there were further changes to the language capabilities,[6][7] such as:
- Improved multi-byte and wide character support in the standard library, introducing
<wchar.h>
and<wctype.h>
as well as multi-byte I/O - Addition of digraphs to the language
- Specification of standard macros for the alternative specification of operators, e.g.
and
for&&
- Specification of the standard macro
__STDC_VERSION__
In addition to the amendment, two technical corrigenda were published by ISO for C90:
Preprocessor test for C95 compatibility
[edit]#if defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199409L
/* C95 compatible source code. */
#elif defined(__STDC__)
/* C89 compatible source code. */
#endif
C99
[edit]In March 2000, ANSI adopted the ISO/IEC 9899:1999 standard.[10] This standard is commonly referred to as C99. Some notable additions to the previous standard include:
- New built-in data types:
long long
,_Bool
,_Complex
, and_Imaginary
- Several new core language features, including static array indices, designated initializers, compound literals, variable-length arrays, flexible array members, variadic macros, and
restrict
keyword - Several new library headers, including
stdint.h
,<tgmath.h>
,fenv.h
,<complex.h>
- Improved compatibility with several C++ features, including inline functions, single-line comments with
//
, mixing declarations and code, and universal character names in identifiers - Removed several dangerous C89 language features such as implicit function declarations and implicit
int
Three technical corrigenda were published by ISO for C99:
- ISO/IEC 9899:1999/Cor 1:2001(E)
- ISO/IEC 9899:1999/Cor 2:2004(E)
- ISO/IEC 9899:1999/Cor 3:2007(E), notable for deprecating the standard library function gets
This standard has been withdrawn by both ANSI/INCITS[11] and ISO/IEC[12] in favour of C11.
C11
[edit]C11 was officially ratified and published on December 8, 2011. Notable features include improved Unicode support, type-generic expressions using the new _Generic
keyword, a cross-platform multi-threading API (threads.h
), and atomic types support in both core language and the library (stdatomic.h
).
One technical corrigendum has been published by ISO for C11:
- ISO/IEC 9899:2011/Cor 1:2012[13]
C17
[edit]C17 was published in June 2018.[14] Rather than introducing new language features, it only addresses defects in C11.[15]
C23
[edit]C23 was published in October 2024, and is the current standard for the C programming language.[16]
Other related ISO publications
[edit]As part of the standardization process, ISO/IEC also publishes technical reports and specifications related to the C language:
- ISO/IEC TR 19769:2004,[17] on library extensions to support Unicode transformation formats, integrated into C11
- ISO/IEC TR 24731-1:2007,[18] on library extensions to support bounds-checked interfaces, integrated into C11
- ISO/IEC TR 18037:2008,[19] on embedded C extensions
- ISO/IEC TR 24732:2009,[20] on decimal floating point arithmetic, superseded by ISO/IEC TS 18661-2:2015
- ISO/IEC TR 24747:2009,[21] on special mathematical functions,
- ISO/IEC TR 24731-2:2010,[22] on library extensions to support dynamic allocation functions
- ISO/IEC TS 17961:2013,[23] on secure coding in C
- ISO/IEC TS 18661-1:2014,[24] on IEC 60559:2011-compatible binary floating-point arithmetic
- ISO/IEC TS 18661-2:2015,[25] on IEC 60559:2011-compatible decimal floating point arithmetic
- ISO/IEC TS 18661-3:2015,[26] on IEC 60559:2011-compatible interchange and extended floating-point types
- ISO/IEC TS 18661-4:2015,[27] on IEC 60559:2011-compatible supplementary functions
More technical specifications are in development and pending approval, including the fifth and final part of TS 18661, a software transactional memory specification, and parallel library extensions.[28]
Support from major compilers
[edit]ANSI C is now supported by almost all the widely used compilers. GCC and Clang are two major C compilers popular today, both based on the C11 with updates including changes from later specifications such as C17.[29][30] Any source code written only in standard C and without any hardware dependent assumptions is virtually guaranteed to compile correctly on any platform with a conforming C implementation. Without such precautions, most programs may compile only on a certain platform or with a particular compiler, due, for example, to the use of non-standard libraries, such as GUI libraries, or to the reliance on compiler- or platform-specific attributes such as the exact size of certain data types and byte endianness.
Compliance detectability
[edit]To mitigate the differences between K&R C and the ANSI C standard, the __STDC__
("standard c") macro can be used to split code into ANSI and K&R sections.
#if defined(__STDC__) && __STDC__
extern int getopt(int, char * const *, const char *);
#else
extern int getopt();
#endif
In the above example, a prototype is used in a function declaration for ANSI compliant implementations, while an obsolescent non-prototype declaration is used otherwise. Those are still ANSI-compliant as of C99. Note how this code checks both definition and evaluation: this is because some implementations may set __STDC__
to zero to indicate non-ANSI compliance.[31]
Compiler support
[edit]List of compilers supporting ANSI C:
- Acornsoft ANSI C (first version in 1988, revised in 1989)
- Amsterdam Compiler Kit (C K&R and C89/90)
- ARM RealView
- Clang, using LLVM backend
- GCC (full C89/90, C99 and C11)
- HP C/ANSI C compiler (C89 and C99)[32]
- IBM XL C/C++ (C11, starting with version 12.1)[33]
- Intel's ICC
- LabWindows/CVI
- LCC
- Oracle Developer Studio
- OpenWatcom (C89/90 and some C99)
- Microsoft Visual C++ (C89/90 and some C99)
- Pelles C (C99 and C11. Windows only.)[34]
- vbcc (C89/90 and C99)
- Tiny C Compiler (C89/90 and some C99)
See also
[edit]- Behavioral Description Language
- Compatibility of C and C++
- C++23, C++20, C++17, C++14, C++11, C++03, C++98, versions of the C++ programming language standard
- C++ Technical Report 1
References
[edit]- ^ Brad Kelechava (2017-09-14). "The Origin of ANSI C and ISO C". Retrieved 2018-08-14.
- ^ Richard Hale Shaw (13 September 1988). "Standard C: The ANSI Draft Grows Up". PC Magazine. Vol. 7, no. 15. pp. 116–117. Retrieved 15 November 2022.
- ^ "Standards - Using the GNU Compiler Collection (GCC)". Retrieved 2012-06-24.
- ^ "INCITS/ISO/IEC 9899". www.techstreet.com. Retrieved 2018-10-03.
- ^ "ISO/IEC 9899:1990 - Programming Languages -- C". Retrieved 2012-06-24.
- ^ Clive D.W. Feather (2010-09-12). "A brief description of Normative Addendum 1".
- ^ "ISO/IEC 9899:1990/Amd 1:1995". International Organization for Standardization. 2013-03-22.
- ^ "ISO/IEC 9899:1990/Cor 1:1994". ISO. Retrieved 2019-01-21.
- ^ "ISO/IEC 9899:1990/Cor 2:1996". ISO. Retrieved 2019-01-21.
- ^ "ISO/IEC 9899:1999". ISO. Retrieved 2019-01-21.
- ^ "INCITS/ISO/IEC 9899-2012". ANSI.
- ^ "ISO/IEC 9899:1999 - Programming Languages -- C". Retrieved 2012-06-24.
- ^ "ISO/IEC 9899:2011/Cor 1:2012". International Organization for Standardization.
- ^ "ISO/IEC 9899:2018 - Information technology -- Programming languages -- C". www.iso.org.
- ^ "The Standard - C". www.iso-9899.info.
- ^ "ISO/IEC 9899:2024 - Information technology — Programming languages — C".
- ^ "ISO/IEC TR 19769:2004". International Organization for Standardization.
- ^ "ISO/IEC TR 24731-1:2007". International Organization for Standardization.
- ^ "ISO/IEC TR 18037:2008". International Organization for Standardization.
- ^ "ISO/IEC TR 24732:2009". International Organization for Standardization.
- ^ "ISO/IEC TR 24747:2009". International Organization for Standardization.
- ^ "ISO/IEC TR 24731-2:2010". International Organization for Standardization.
- ^ "ISO/IEC TS 17961:2013". International Organization for Standardization.
- ^ "ISO/IEC TS 18661-1:2014". International Organization for Standardization.
- ^ "ISO/IEC TS 18661-2:2015". International Organization for Standardization.
- ^ "ISO/IEC TS 18661-3:2015". International Organization for Standardization.
- ^ "ISO/IEC TS 18661-4:2015". International Organization for Standardization.
- ^ "Experimental C features". cppreference.com. Retrieved 16 January 2016.
- ^ "2 Language Standards Supported by GCC - 2.1 C Language". Using the GNU Compiler Collection (GCC). GCC, the GNU Compiler Collection. Retrieved 2019-02-05.
- ^ "Language Compatibility". Clang C Language Family Frontend for LLVM. Retrieved 2019-02-05.
- ^ "Standard predefined macro names". www.ibm.com. Retrieved 2019-04-10.
- ^ "HP C/ANSI C developer's bundle". Retrieved 2015-07-12.
- ^ Support for ISO C11 added to IBM XL C/C++ compilers
- ^ link to Pelles C pages
Further reading
[edit]- Schreiner, Axel-Tobias (1993). Object Oriented Programming with ANSI-C. Hanser. ISBN 3-446-17426-5.
External links
[edit]- ISO C working group
- Draft ANSI C Standard (ANSI X3J11/88-090) (May 13, 1988), Third Public Review
- Draft ANSI C Rationale (ANSI X3J11/88-151) (Nov 18, 1988)
- C Information Bulletin #1 (ANSI X3J11/93-007) (May 27, 1992)
- ANSI C Yacc grammar
- "ISO/IEC 9899:1999 Programming Languages -- C". American National Standards Institute. Archived from the original on 2011-07-25. Retrieved 2009-08-06.
- "ANSI Standards Action Vol. 36, #48" (PDF). American National Standards Institute. 2005-12-02. Archived from the original (PDF) on 2016-03-04. Retrieved 2009-08-06.