C23 (C standard revision)

From testwiki
Jump to navigation Jump to search

Template:Short description Template:C language revisions C23, formally ISO/IEC 9899:2024, is the current open standard for the C programming language, which supersedes C17 (standard ISO/IEC 9899:2018).[1] It was started in 2016 informally as C2x,[2] and was published on October 31, 2024.[3] The freely available draft most similar to the one published is document N3220[4] (see Available texts, below). The first WG14 meeting for the C2x draft was held in October 2019,[5] virtual remote meetings were held in 2020 due to the COVID-19 pandemic, then various teleconference meetings continued to occur through 2024.

In C23, the value of __STDC_VERSION__ changes from 201710L to 202311L. The common names "C17" and "C23" reflect these values, which are frozen prior to final adoption, rather than the years in the ISO standards identifiers (9899:2018 and 9899:2024).

Features

Changes integrated into the latest working draft of C23 are listed below.[6]

Standard Library

New functions

  • Add memset_explicit() function in <string.h> to erase sensitive data, where memory store must always be performed regardless of optimizations.[7]
  • Add memccpy() function in <string.h> to efficiently concatenate strings – similar to POSIX and SVID C extensions.[8]
  • Add strdup() and strndup() functions in <string.h> to allocate a copy of a string – similar to POSIX and SVID C extensions.[9]
  • Add memalignment() function in <stdlib.h> to determine the byte alignment of a pointer.[10]
  • Add bit utility functions / macros / types in new header <stdbit.h> to examine many integer types. All start with stdc_ to minimize conflict with legacy code and 3rd party libraries.[11]
    • In the following, replace * with uc, us, ui, ul, ull for five function names, or blank for a type-generic macro.[11]
    • Add stdc_count_ones*() and stdc_count_zeros*() to count number of 1 or 0 bits in value.[11]
    • Add stdc_leading_ones*() and stdc_leading_zeros*() to count leading 1 or 0 bits in value.[11]
    • Add stdc_trailing_ones*() and stdc_trailing_zeros*() to count trailing 1 or 0 bits in value.[11]
    • Add stdc_first_leading_one*() and stdc_first_leading_zero*() to find first leading bit with 1 or 0 in value.[11]
    • Add stdc_first_trailing_one*() and stdc_first_trailing_zero*() to find first trailing bit with 1 or 0 in value.[11]
    • Add stdc_has_single_bit*() to determine if value is an exact power of 2 (return true if and only if there is a single 1 bit).[11]
    • Add stdc_bit_floor*() to determine the largest integral power of 2 that is not greater than value.[11]
    • Add stdc_bit_ceil*() to determine the smallest integral power of 2 that is not less than value.[11]
    • Add stdc_bit_width*() to determine number of bits to represent a value.[11]
  • Add timegm() function in <time.h> to convert time structure into calendar time value - similar to function in glibc and musl libraries.[12]
  • New <math.h> functions based on IEEE 754-2019 recommendations, such as trigonometry functions operating on units of πx and exp10.[13]

Existing functions

Preprocessor

Types

Constants

Keywords

Syntax

  • Labels can appear before declarations and at the end of compound statements.[40]
  • Unnamed parameters in function definitions.[41]
  • Zero initialization with {} (including initialization of VLAs).[42]
  • Variadic functions no longer need a named argument before the ellipsis and the Template:C-lang macro no longer needs a second argument nor does it evaluate any argument after the first one if present.[43]
  • Add C++11 style attribute syntax[44] using double square brackets Template:C-lang. In addition to C++11 attributes listed below, add new attributes:
    • [[unsequenced]][45] allows compiler optimizations for functions producing repeatable outputs only based on their parameters
    • [[reproducible]],[45] similar to [[unsequenced]], but for functions whose call order also matters
  • Add single-argument _Static_assert for compatibility with C++17.[46]
  • Functions with no arguments listed in the prototype (e.g. void foo()) are understood as taking no arguments (see removal of K&R function declarations)

C++ compatibility

Other features

  • Support for the ISO/IEC 60559:2020, the current version of the IEEE 754 standard for floating-point arithmetic, with extended binary floating-point arithmetic and (optional) decimal floating-point arithmetic.[57][58]

Obsolete features

Some old obsolete features are either removed or deprecated from the working draft of C23:

  • Remove trigraphs.[63]
  • Remove K&R function definitions/declarations (with no information about the function arguments).[64][65]
  • Remove representations for signed integers other than two's complement. Two's complement signed integer representation will be required.[66]
  • The Template:C-lang macros in <float.h> are obsolescent features.[67]

Compiler support

The following compilers implement an experimental compiler flag to support this standard:

Available texts

Like other editions of the C standard, the official ISO text of the standard is not freely available.

The latest working draft pre-C23 that was made public was N3096,[6] dated 2023-04-01. In the months that followed this draft, hundreds of changes[71] were made before producing the working draft N3149 dated 2023-07-09 and the official draft standard N3219 dated 2024-02-22.[71][72] Neither of these later drafts is public.[71][72]

On the same date that the draft standard N3219 was announced, a new working draft N3220[4] was made public. While this document is officially described[72] as a draft of the future version "C2Y" of the standard, the accompanying "Editor's Report" specifies that N3220 differs from the draft C23 standard N3219 only by a fix to one footnote in Annex K.[72]

See also

Template:Portal

References

Template:Reflist

Further reading

  • N3096 (last freely-available working draft before C23); WG14; April 2023. (free download)
  • N3149 (working draft of C23 standard); WG14; July 2023. (not available to public)
  • N3219 (ISO/IEC 9899:2023 DIS Draft); WG14; February 2024. (ISO draft available but not free)
  • ISO/IEC 9899:2024 (official C23 standard); ISO; 2024. (planning for release in 2024)
  • N3220 (first working draft after C23; differs from draft standard N3219 only in one footnote); WG14; February 2024. (free download)

Template:S-start Template:S-bef Template:S-ttl Template:S-non Template:End

Template:C programming language

  1. Template:Cite web
  2. Template:Cite web
  3. Template:Cite web
  4. 4.0 4.1 Template:Cite web
  5. Template:Cite web
  6. 6.0 6.1 Template:Cite web
  7. Template:Cite web
  8. Template:Cite web
  9. Template:Cite web
  10. Template:Cite web
  11. 11.00 11.01 11.02 11.03 11.04 11.05 11.06 11.07 11.08 11.09 11.10 Template:Cite web
  12. Template:Cite web
  13. See N3096 § B.11 for a useful overview. The functions were added in separate documents: N2488, its updated versions, and its refs.
  14. 14.0 14.1 14.2 Template:Cite web
  15. Template:Cite web
  16. 16.0 16.1 Template:Cite web
  17. Template:Cite web
  18. Template:Cite web
  19. Template:Cite web
  20. Template:Cite web
  21. Template:Cite web
  22. Template:Cite web
  23. 23.0 23.1 Template:Cite web
  24. Template:Cite web
  25. Template:Cite web
  26. Template:Cite web
  27. Template:Cite web
  28. Template:Cite web
  29. Template:Cite web
  30. Template:Cite web
  31. Template:Cite web
  32. Template:Cite web
  33. Template:Cite web
  34. Template:Cite web
  35. Template:Cite web
  36. Template:Cite web
  37. Template:Cite web
  38. Template:Cite web
  39. Template:Cite web
  40. Template:Cite web
  41. Template:Cite web
  42. Template:Cite web
  43. Template:Cite web
  44. Template:Cite web
  45. 45.0 45.1 Template:Cite web
  46. Template:Cite web
  47. Template:Cite web
  48. Template:Cite web
  49. Template:Cite web
  50. Template:Cite web
  51. Template:Cite web
  52. Template:Cite web
  53. Template:Cite web
  54. Template:Cite web
  55. Template:Cite web
  56. What is the point of the UTF-8 character literals proposed for C++17?; Stack Overflow.
  57. Template:Cite web
  58. Template:Cite web
  59. Template:Cite web
  60. Template:Cite web
  61. Template:Cite web
  62. Template:Cite web
  63. Template:Cite web
  64. Template:Cite web
  65. Template:Cite web
  66. Template:Cite web
  67. Template:Cite web
  68. Template:Cite web
  69. Template:Cite web
  70. Template:Cite web
  71. 71.0 71.1 71.2 Template:Cite web
  72. 72.0 72.1 72.2 72.3 Template:Cite web