C-Extensions.html 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  2. <html>
  3. <!-- Copyright (C) 1988-2017 Free Software Foundation, Inc.
  4. Permission is granted to copy, distribute and/or modify this document
  5. under the terms of the GNU Free Documentation License, Version 1.3 or
  6. any later version published by the Free Software Foundation; with the
  7. Invariant Sections being "Funding Free Software", the Front-Cover
  8. Texts being (a) (see below), and with the Back-Cover Texts being (b)
  9. (see below). A copy of the license is included in the section entitled
  10. "GNU Free Documentation License".
  11. (a) The FSF's Front-Cover Text is:
  12. A GNU Manual
  13. (b) The FSF's Back-Cover Text is:
  14. You have freedom to copy and modify this GNU Manual, like GNU
  15. software. Copies published by the Free Software Foundation raise
  16. funds for GNU development. -->
  17. <!-- Created by GNU Texinfo 5.2, http://www.gnu.org/software/texinfo/ -->
  18. <head>
  19. <title>Using the GNU Compiler Collection (GCC): C Extensions</title>
  20. <meta name="description" content="Using the GNU Compiler Collection (GCC): C Extensions">
  21. <meta name="keywords" content="Using the GNU Compiler Collection (GCC): C Extensions">
  22. <meta name="resource-type" content="document">
  23. <meta name="distribution" content="global">
  24. <meta name="Generator" content="makeinfo">
  25. <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  26. <link href="index.html#Top" rel="start" title="Top">
  27. <link href="Option-Index.html#Option-Index" rel="index" title="Option Index">
  28. <link href="index.html#SEC_Contents" rel="contents" title="Table of Contents">
  29. <link href="index.html#Top" rel="up" title="Top">
  30. <link href="Statement-Exprs.html#Statement-Exprs" rel="next" title="Statement Exprs">
  31. <link href="Exception-handling.html#Exception-handling" rel="prev" title="Exception handling">
  32. <style type="text/css">
  33. <!--
  34. a.summary-letter {text-decoration: none}
  35. blockquote.smallquotation {font-size: smaller}
  36. div.display {margin-left: 3.2em}
  37. div.example {margin-left: 3.2em}
  38. div.indentedblock {margin-left: 3.2em}
  39. div.lisp {margin-left: 3.2em}
  40. div.smalldisplay {margin-left: 3.2em}
  41. div.smallexample {margin-left: 3.2em}
  42. div.smallindentedblock {margin-left: 3.2em; font-size: smaller}
  43. div.smalllisp {margin-left: 3.2em}
  44. kbd {font-style:oblique}
  45. pre.display {font-family: inherit}
  46. pre.format {font-family: inherit}
  47. pre.menu-comment {font-family: serif}
  48. pre.menu-preformatted {font-family: serif}
  49. pre.smalldisplay {font-family: inherit; font-size: smaller}
  50. pre.smallexample {font-size: smaller}
  51. pre.smallformat {font-family: inherit; font-size: smaller}
  52. pre.smalllisp {font-size: smaller}
  53. span.nocodebreak {white-space:nowrap}
  54. span.nolinebreak {white-space:nowrap}
  55. span.roman {font-family:serif; font-weight:normal}
  56. span.sansserif {font-family:sans-serif; font-weight:normal}
  57. ul.no-bullet {list-style: none}
  58. -->
  59. </style>
  60. </head>
  61. <body lang="en" bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#800080" alink="#FF0000">
  62. <a name="C-Extensions"></a>
  63. <div class="header">
  64. <p>
  65. Next: <a href="C_002b_002b-Extensions.html#C_002b_002b-Extensions" accesskey="n" rel="next">C++ Extensions</a>, Previous: <a href="C_002b_002b-Implementation.html#C_002b_002b-Implementation" accesskey="p" rel="prev">C++ Implementation</a>, Up: <a href="index.html#Top" accesskey="u" rel="up">Top</a> &nbsp; [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="Option-Index.html#Option-Index" title="Index" rel="index">Index</a>]</p>
  66. </div>
  67. <hr>
  68. <a name="Extensions-to-the-C-Language-Family"></a>
  69. <h2 class="chapter">6 Extensions to the C Language Family</h2>
  70. <a name="index-extensions_002c-C-language"></a>
  71. <a name="index-C-language-extensions"></a>
  72. <a name="index-pedantic-2"></a>
  73. <p>GNU C provides several language features not found in ISO standard C.
  74. (The <samp>-pedantic</samp> option directs GCC to print a warning message if
  75. any of these features is used.) To test for the availability of these
  76. features in conditional compilation, check for a predefined macro
  77. <code>__GNUC__</code>, which is always defined under GCC.
  78. </p>
  79. <p>These extensions are available in C and Objective-C. Most of them are
  80. also available in C++. See <a href="C_002b_002b-Extensions.html#C_002b_002b-Extensions">Extensions to the
  81. C++ Language</a>, for extensions that apply <em>only</em> to C++.
  82. </p>
  83. <p>Some features that are in ISO C99 but not C90 or C++ are also, as
  84. extensions, accepted by GCC in C90 mode and in C++.
  85. </p>
  86. <table class="menu" border="0" cellspacing="0">
  87. <tr><td align="left" valign="top">&bull; <a href="Statement-Exprs.html#Statement-Exprs" accesskey="1">Statement Exprs</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Putting statements and declarations inside expressions.
  88. </td></tr>
  89. <tr><td align="left" valign="top">&bull; <a href="Local-Labels.html#Local-Labels" accesskey="2">Local Labels</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Labels local to a block.
  90. </td></tr>
  91. <tr><td align="left" valign="top">&bull; <a href="Labels-as-Values.html#Labels-as-Values" accesskey="3">Labels as Values</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Getting pointers to labels, and computed gotos.
  92. </td></tr>
  93. <tr><td align="left" valign="top">&bull; <a href="Nested-Functions.html#Nested-Functions" accesskey="4">Nested Functions</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">As in Algol and Pascal, lexical scoping of functions.
  94. </td></tr>
  95. <tr><td align="left" valign="top">&bull; <a href="Constructing-Calls.html#Constructing-Calls" accesskey="5">Constructing Calls</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Dispatching a call to another function.
  96. </td></tr>
  97. <tr><td align="left" valign="top">&bull; <a href="Typeof.html#Typeof" accesskey="6">Typeof</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>typeof</code>: referring to the type of an expression.
  98. </td></tr>
  99. <tr><td align="left" valign="top">&bull; <a href="Conditionals.html#Conditionals" accesskey="7">Conditionals</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Omitting the middle operand of a &lsquo;<samp>?:</samp>&rsquo; expression.
  100. </td></tr>
  101. <tr><td align="left" valign="top">&bull; <a href="_005f_005fint128.html#g_t_005f_005fint128" accesskey="8">__int128</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">128-bit integers&mdash;<code>__int128</code>.
  102. </td></tr>
  103. <tr><td align="left" valign="top">&bull; <a href="Long-Long.html#Long-Long" accesskey="9">Long Long</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Double-word integers&mdash;<code>long long int</code>.
  104. </td></tr>
  105. <tr><td align="left" valign="top">&bull; <a href="Complex.html#Complex">Complex</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Data types for complex numbers.
  106. </td></tr>
  107. <tr><td align="left" valign="top">&bull; <a href="Floating-Types.html#Floating-Types">Floating Types</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Additional Floating Types.
  108. </td></tr>
  109. <tr><td align="left" valign="top">&bull; <a href="Half_002dPrecision.html#Half_002dPrecision">Half-Precision</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Half-Precision Floating Point.
  110. </td></tr>
  111. <tr><td align="left" valign="top">&bull; <a href="Decimal-Float.html#Decimal-Float">Decimal Float</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Decimal Floating Types.
  112. </td></tr>
  113. <tr><td align="left" valign="top">&bull; <a href="Hex-Floats.html#Hex-Floats">Hex Floats</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Hexadecimal floating-point constants.
  114. </td></tr>
  115. <tr><td align="left" valign="top">&bull; <a href="Fixed_002dPoint.html#Fixed_002dPoint">Fixed-Point</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Fixed-Point Types.
  116. </td></tr>
  117. <tr><td align="left" valign="top">&bull; <a href="Named-Address-Spaces.html#Named-Address-Spaces">Named Address Spaces</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Named address spaces.
  118. </td></tr>
  119. <tr><td align="left" valign="top">&bull; <a href="Zero-Length.html#Zero-Length">Zero Length</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Zero-length arrays.
  120. </td></tr>
  121. <tr><td align="left" valign="top">&bull; <a href="Empty-Structures.html#Empty-Structures">Empty Structures</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Structures with no members.
  122. </td></tr>
  123. <tr><td align="left" valign="top">&bull; <a href="Variable-Length.html#Variable-Length">Variable Length</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Arrays whose length is computed at run time.
  124. </td></tr>
  125. <tr><td align="left" valign="top">&bull; <a href="Variadic-Macros.html#Variadic-Macros">Variadic Macros</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Macros with a variable number of arguments.
  126. </td></tr>
  127. <tr><td align="left" valign="top">&bull; <a href="Escaped-Newlines.html#Escaped-Newlines">Escaped Newlines</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Slightly looser rules for escaped newlines.
  128. </td></tr>
  129. <tr><td align="left" valign="top">&bull; <a href="Subscripting.html#Subscripting">Subscripting</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Any array can be subscripted, even if not an lvalue.
  130. </td></tr>
  131. <tr><td align="left" valign="top">&bull; <a href="Pointer-Arith.html#Pointer-Arith">Pointer Arith</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Arithmetic on <code>void</code>-pointers and function pointers.
  132. </td></tr>
  133. <tr><td align="left" valign="top">&bull; <a href="Pointers-to-Arrays.html#Pointers-to-Arrays">Pointers to Arrays</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Pointers to arrays with qualifiers work as expected.
  134. </td></tr>
  135. <tr><td align="left" valign="top">&bull; <a href="Initializers.html#Initializers">Initializers</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Non-constant initializers.
  136. </td></tr>
  137. <tr><td align="left" valign="top">&bull; <a href="Compound-Literals.html#Compound-Literals">Compound Literals</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Compound literals give structures, unions
  138. or arrays as values.
  139. </td></tr>
  140. <tr><td align="left" valign="top">&bull; <a href="Designated-Inits.html#Designated-Inits">Designated Inits</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Labeling elements of initializers.
  141. </td></tr>
  142. <tr><td align="left" valign="top">&bull; <a href="Case-Ranges.html#Case-Ranges">Case Ranges</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">&lsquo;case 1 ... 9&rsquo; and such.
  143. </td></tr>
  144. <tr><td align="left" valign="top">&bull; <a href="Cast-to-Union.html#Cast-to-Union">Cast to Union</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Casting to union type from any member of the union.
  145. </td></tr>
  146. <tr><td align="left" valign="top">&bull; <a href="Mixed-Declarations.html#Mixed-Declarations">Mixed Declarations</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Mixing declarations and code.
  147. </td></tr>
  148. <tr><td align="left" valign="top">&bull; <a href="Function-Attributes.html#Function-Attributes">Function Attributes</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Declaring that functions have no side effects,
  149. or that they can never return.
  150. </td></tr>
  151. <tr><td align="left" valign="top">&bull; <a href="Variable-Attributes.html#Variable-Attributes">Variable Attributes</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Specifying attributes of variables.
  152. </td></tr>
  153. <tr><td align="left" valign="top">&bull; <a href="Type-Attributes.html#Type-Attributes">Type Attributes</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Specifying attributes of types.
  154. </td></tr>
  155. <tr><td align="left" valign="top">&bull; <a href="Label-Attributes.html#Label-Attributes">Label Attributes</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Specifying attributes on labels.
  156. </td></tr>
  157. <tr><td align="left" valign="top">&bull; <a href="Enumerator-Attributes.html#Enumerator-Attributes">Enumerator Attributes</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Specifying attributes on enumerators.
  158. </td></tr>
  159. <tr><td align="left" valign="top">&bull; <a href="Statement-Attributes.html#Statement-Attributes">Statement Attributes</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Specifying attributes on statements.
  160. </td></tr>
  161. <tr><td align="left" valign="top">&bull; <a href="Attribute-Syntax.html#Attribute-Syntax">Attribute Syntax</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Formal syntax for attributes.
  162. </td></tr>
  163. <tr><td align="left" valign="top">&bull; <a href="Function-Prototypes.html#Function-Prototypes">Function Prototypes</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Prototype declarations and old-style definitions.
  164. </td></tr>
  165. <tr><td align="left" valign="top">&bull; <a href="C_002b_002b-Comments.html#C_002b_002b-Comments">C++ Comments</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">C++ comments are recognized.
  166. </td></tr>
  167. <tr><td align="left" valign="top">&bull; <a href="Dollar-Signs.html#Dollar-Signs">Dollar Signs</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Dollar sign is allowed in identifiers.
  168. </td></tr>
  169. <tr><td align="left" valign="top">&bull; <a href="Character-Escapes.html#Character-Escapes">Character Escapes</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">&lsquo;<samp>\e</samp>&rsquo; stands for the character <tt class="key">ESC</tt>.
  170. </td></tr>
  171. <tr><td align="left" valign="top">&bull; <a href="Alignment.html#Alignment">Alignment</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Inquiring about the alignment of a type or variable.
  172. </td></tr>
  173. <tr><td align="left" valign="top">&bull; <a href="Inline.html#Inline">Inline</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Defining inline functions (as fast as macros).
  174. </td></tr>
  175. <tr><td align="left" valign="top">&bull; <a href="Volatiles.html#Volatiles">Volatiles</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">What constitutes an access to a volatile object.
  176. </td></tr>
  177. <tr><td align="left" valign="top">&bull; <a href="Using-Assembly-Language-with-C.html#Using-Assembly-Language-with-C">Using Assembly Language with C</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Instructions and extensions for interfacing C with assembler.
  178. </td></tr>
  179. <tr><td align="left" valign="top">&bull; <a href="Alternate-Keywords.html#Alternate-Keywords">Alternate Keywords</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>__const__</code>, <code>__asm__</code>, etc., for header files.
  180. </td></tr>
  181. <tr><td align="left" valign="top">&bull; <a href="Incomplete-Enums.html#Incomplete-Enums">Incomplete Enums</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top"><code>enum foo;</code>, with details to follow.
  182. </td></tr>
  183. <tr><td align="left" valign="top">&bull; <a href="Function-Names.html#Function-Names">Function Names</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Printable strings which are the name of the current
  184. function.
  185. </td></tr>
  186. <tr><td align="left" valign="top">&bull; <a href="Return-Address.html#Return-Address">Return Address</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Getting the return or frame address of a function.
  187. </td></tr>
  188. <tr><td align="left" valign="top">&bull; <a href="Vector-Extensions.html#Vector-Extensions">Vector Extensions</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Using vector instructions through built-in functions.
  189. </td></tr>
  190. <tr><td align="left" valign="top">&bull; <a href="Offsetof.html#Offsetof">Offsetof</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Special syntax for implementing <code>offsetof</code>.
  191. </td></tr>
  192. <tr><td align="left" valign="top">&bull; <a href="_005f_005fsync-Builtins.html#g_t_005f_005fsync-Builtins">__sync Builtins</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Legacy built-in functions for atomic memory access.
  193. </td></tr>
  194. <tr><td align="left" valign="top">&bull; <a href="_005f_005fatomic-Builtins.html#g_t_005f_005fatomic-Builtins">__atomic Builtins</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Atomic built-in functions with memory model.
  195. </td></tr>
  196. <tr><td align="left" valign="top">&bull; <a href="Integer-Overflow-Builtins.html#Integer-Overflow-Builtins">Integer Overflow Builtins</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Built-in functions to perform arithmetics and
  197. arithmetic overflow checking.
  198. </td></tr>
  199. <tr><td align="left" valign="top">&bull; <a href="x86-specific-memory-model-extensions-for-transactional-memory.html#x86-specific-memory-model-extensions-for-transactional-memory">x86 specific memory model extensions for transactional memory</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">x86 memory models.
  200. </td></tr>
  201. <tr><td align="left" valign="top">&bull; <a href="Object-Size-Checking.html#Object-Size-Checking">Object Size Checking</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Built-in functions for limited buffer overflow
  202. checking.
  203. </td></tr>
  204. <tr><td align="left" valign="top">&bull; <a href="Pointer-Bounds-Checker-builtins.html#Pointer-Bounds-Checker-builtins">Pointer Bounds Checker builtins</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Built-in functions for Pointer Bounds Checker.
  205. </td></tr>
  206. <tr><td align="left" valign="top">&bull; <a href="Cilk-Plus-Builtins.html#Cilk-Plus-Builtins">Cilk Plus Builtins</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Built-in functions for the Cilk Plus language extension.
  207. </td></tr>
  208. <tr><td align="left" valign="top">&bull; <a href="Other-Builtins.html#Other-Builtins">Other Builtins</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Other built-in functions.
  209. </td></tr>
  210. <tr><td align="left" valign="top">&bull; <a href="Target-Builtins.html#Target-Builtins">Target Builtins</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Built-in functions specific to particular targets.
  211. </td></tr>
  212. <tr><td align="left" valign="top">&bull; <a href="Target-Format-Checks.html#Target-Format-Checks">Target Format Checks</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Format checks specific to particular targets.
  213. </td></tr>
  214. <tr><td align="left" valign="top">&bull; <a href="Pragmas.html#Pragmas">Pragmas</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Pragmas accepted by GCC.
  215. </td></tr>
  216. <tr><td align="left" valign="top">&bull; <a href="Unnamed-Fields.html#Unnamed-Fields">Unnamed Fields</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Unnamed struct/union fields within structs/unions.
  217. </td></tr>
  218. <tr><td align="left" valign="top">&bull; <a href="Thread_002dLocal.html#Thread_002dLocal">Thread-Local</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Per-thread variables.
  219. </td></tr>
  220. <tr><td align="left" valign="top">&bull; <a href="Binary-constants.html#Binary-constants">Binary constants</a>:</td><td>&nbsp;&nbsp;</td><td align="left" valign="top">Binary constants using the &lsquo;<samp>0b</samp>&rsquo; prefix.
  221. </td></tr>
  222. </table>
  223. <hr>
  224. <div class="header">
  225. <p>
  226. Next: <a href="C_002b_002b-Extensions.html#C_002b_002b-Extensions" accesskey="n" rel="next">C++ Extensions</a>, Previous: <a href="C_002b_002b-Implementation.html#C_002b_002b-Implementation" accesskey="p" rel="prev">C++ Implementation</a>, Up: <a href="index.html#Top" accesskey="u" rel="up">Top</a> &nbsp; [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="Option-Index.html#Option-Index" title="Index" rel="index">Index</a>]</p>
  227. </div>
  228. </body>
  229. </html>