Difference between revisions of "cpp/types/integer"
(INTn_C should appear here too! /cpp/header is a helper page, this is the main page) |
(Fix chapter name and id) |
||
(30 intermediate revisions by 13 users not shown) | |||
Line 1: | Line 1: | ||
− | {{title | Fixed width integer types {{mark since c++11}}}} | + | {{title|Fixed width integer types {{mark since c++11}}}} |
{{cpp/types/navbar}} | {{cpp/types/navbar}} | ||
===Types=== | ===Types=== | ||
− | |||
{{dsc begin}} | {{dsc begin}} | ||
− | {{dsc header | cstdint}} | + | {{dsc header|cstdint}} |
− | {{dsc | | + | {{dsc inc|cpp/types/dsc intN_t}} |
− | {{dsc | | + | {{dsc inc|cpp/types/dsc int_fastN_t}} |
− | {{dsc | | + | {{dsc inc|cpp/types/dsc int_leastN_t}} |
− | {{dsc | | + | {{dsc inc|cpp/types/dsc intmax_t}} |
− | {{dsc | | + | {{dsc inc|cpp/types/dsc intptr_t}} |
− | {{dsc | | + | {{dsc inc|cpp/types/dsc uintN_t}} |
− | {{dsc | | + | {{dsc inc|cpp/types/dsc uint_fastN_t}} |
− | {{dsc | | + | {{dsc inc|cpp/types/dsc uint_leastN_t}} |
− | {{dsc | | + | {{dsc inc|cpp/types/dsc uintmax_t}} |
+ | {{dsc inc|cpp/types/dsc uintptr_t}} | ||
{{dsc end}} | {{dsc end}} | ||
+ | |||
+ | The implementation may define typedef names {{tt|int''N''_t}}, {{tt|int_fast''N''_t}}, {{tt|int_least''N''_t}}, {{tt|uint''N''_t}}, {{tt|uint_fast''N''_t}}, and {{tt|uint_least''N''_t}} when ''N'' is not 8, 16, 32 or 64. Typedef names of the form {{tt|int''N''_t}} may only be defined if the implementation supports an integer type of that width with no padding. Thus, {{tt|std::uint24_t}} denotes an unsigned integer type with a width of exactly 24 bits. | ||
+ | |||
+ | Each of the macros listed in below is defined if and only if the implementation defines the corresponding typedef name. The macros {{tt|INT''N''_C}} and {{tt|UINT''N''_C}} correspond to the typedef names {{tt|int_least''N''_t}} and {{tt|uint_least''N''_t}}, respectively. | ||
===Macro constants=== | ===Macro constants=== | ||
{{dsc begin}} | {{dsc begin}} | ||
− | {{dsc header | cstdint}} | + | {{dsc header|cstdint}} |
− | {{dsc h2 | Signed integers : minimum value}} | + | {{dsc h2|Signed integers : minimum value}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc INTn_MIN}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc INT_FASTn_MIN}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc INT_LEASTn_MIN}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc INTPTR_MIN}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc INTMAX_MIN}} |
− | {{dsc h2 | Signed integers : maximum value| nolink=true }} | + | {{dsc h2|Signed integers : maximum value|nolink=true}} |
− | + | {{dsc inc|cpp/types/dsc INTn_MAX}} | |
− | {{dsc | + | {{dsc inc|cpp/types/dsc INT_FASTn_MAX}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc INT_LEAST8_MAX}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc INTPTR_MAX}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc INTMAX_MAX}} |
− | {{dsc | + | {{dsc h2|Unsigned integers : maximum value|nolink=true}} |
− | {{dsc h2 | Unsigned integers : maximum value| nolink=true }}{{dsc | + | {{dsc inc|cpp/types/dsc UINTn_MAX}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc UINT_FASTn_MAX}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc UINT_LEASTn_MAX}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc UINTPTR_MAX}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc UINTMAX_MAX}} |
{{dsc end}} | {{dsc end}} | ||
===Function macros for minimum-width integer constants=== | ===Function macros for minimum-width integer constants=== | ||
− | |||
{{dsc begin}} | {{dsc begin}} | ||
− | {{dsc | + | {{dsc inc|cpp/types/dsc INTn_C}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc INTMAX_C}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc UINTn_C}} |
− | {{dsc | + | {{dsc inc|cpp/types/dsc UINTMAX_C}} |
{{dsc end}} | {{dsc end}} | ||
− | {{ | + | {{source| |
#include <cstdint> | #include <cstdint> | ||
− | UINT64_C(0x123) // expands to | + | UINT64_C(0x123) // expands to a literal of type uint_least64_t and value 0x123 |
}} | }} | ||
===Format macro constants=== | ===Format macro constants=== | ||
{{dsc begin}} | {{dsc begin}} | ||
− | {{dsc header | cinttypes}} | + | {{dsc header|cinttypes}} |
{{dsc end}} | {{dsc end}} | ||
+ | |||
====Format constants for the {{lc|std::fprintf}} family of functions==== | ====Format constants for the {{lc|std::fprintf}} family of functions==== | ||
+ | Each of the {{tt|PRI}} macros listed here is defined if and only if the implementation defines the corresponding typedef name. | ||
+ | |||
{| class="wikitable" style="text-align:center; font-size:85%; max-width:90em;" | {| class="wikitable" style="text-align:center; font-size:85%; max-width:90em;" | ||
|- | |- | ||
− | ! rowspan= | + | ! rowspan=2|Equivalent<br>for {{c/core|int}} or<br>{{c/core|unsigned int}} |
− | ! rowspan= | + | ! rowspan=2|Description |
− | ! colspan=5 | Macros for data types | + | ! colspan=5|Macros for data types |
|- | |- | ||
− | | <br><br><br><br>{{vertical|{{ | + | |<br><br><br><br>{{vertical|{{tt|std::int}}'''x'''{{tt|_t}}}}<br><br><br><br> |
− | | {{vertical|{{ | + | |{{vertical|{{tt|std::int_least}}'''x'''{{lc|_t}}}} |
− | | {{vertical|{{ | + | |{{vertical|{{tt|std::int_fast}}'''x'''{{lc|_t}}}} |
− | + | |{{vertical|{{tt|std::intmax_t}}}} | |
− | + | |{{vertical|{{tt|std::intptr_t}}}} | |
|- | |- | ||
− | | | + | ! {{tt|d}} |
+ | |rowspan=2 style="text-align:left;"|output of a signed decimal integer value | ||
+ | |PRId'''x''' | ||
+ | |PRIdLEAST'''x''' | ||
+ | |PRIdFAST'''x''' | ||
+ | |PRIdMAX | ||
+ | |PRIdPTR | ||
|- | |- | ||
− | ! {{tt| | + | ! {{tt|i}} |
− | | | + | |PRIi'''x''' |
− | + | |PRIiLEAST'''x''' | |
− | | | + | |PRIiFAST'''x''' |
− | | | + | |PRIiMAX |
− | | | + | |PRIiPTR |
− | | | + | |
|- | |- | ||
− | ! {{tt| | + | ! {{tt|u}} |
− | | | + | |style="text-align:left;"|output of an unsigned decimal integer value |
− | | | + | |PRIu'''x''' |
− | | | + | |PRIuLEAST'''x''' |
− | | | + | |PRIuFAST'''x''' |
− | | | + | |PRIuMAX |
+ | |PRIuPTR | ||
|- | |- | ||
− | ! {{tt| | + | ! {{tt|o}} |
− | | style="text-align:left;" | output of an unsigned | + | |style="text-align:left;"|output of an unsigned octal integer value |
− | | | + | |PRIo'''x''' |
− | | | + | |PRIoLEAST'''x''' |
− | | | + | |PRIoFAST'''x''' |
− | | | + | |PRIoMAX |
− | | | + | |PRIoPTR |
|- | |- | ||
− | ! {{tt| | + | ! {{tt|x}} |
− | | style="text-align:left;" | output of an unsigned | + | |style="text-align:left;"|output of an unsigned lowercase hexadecimal integer value |
− | | | + | |PRIx'''x''' |
− | | | + | |PRIxLEAST'''x''' |
− | | | + | |PRIxFAST'''x''' |
− | | | + | |PRIxMAX |
− | | | + | |PRIxPTR |
|- | |- | ||
− | ! {{tt| | + | ! {{tt|X}} |
− | + | |style="text-align:left;"|output of an unsigned uppercase hexadecimal integer value | |
− | + | |PRIX'''x''' | |
− | + | |PRIXLEAST'''x''' | |
− | + | |PRIXFAST'''x''' | |
− | + | |PRIXMAX | |
− | + | |PRIXPTR | |
− | + | ||
− | + | ||
− | | style="text-align:left;" | output of an unsigned uppercase hexadecimal integer value | + | |
− | | PRIX'''x''' | + | |
− | | PRIXLEAST'''x''' | + | |
− | | PRIXFAST'''x''' | + | |
− | | PRIXMAX | + | |
− | | PRIXPTR | + | |
|} | |} | ||
+ | |||
====Format constants for the {{lc|std::fscanf}} family of functions==== | ====Format constants for the {{lc|std::fscanf}} family of functions==== | ||
+ | Each of the {{tt|SCN}} macros listed in here is defined if and only if the implementation defines the corresponding typedef name and has a suitable {{lc|std::fscanf}} length modifier for the type. | ||
+ | |||
{| class="wikitable" style="text-align:center; font-size:85%; max-width:90em;" | {| class="wikitable" style="text-align:center; font-size:85%; max-width:90em;" | ||
|- | |- | ||
− | ! rowspan= | + | ! rowspan=2|Equivalent<br>for {{c/core|int}} or<br>{{c/core|unsigned int}} |
− | ! rowspan= | + | ! rowspan=2|Description |
− | ! colspan=5 | Macros for data types | + | ! colspan=5|Macros for data types |
|- | |- | ||
− | | <br><br><br><br>{{vertical|{{ | + | |<br><br><br><br>{{vertical|{{tt|std::int}}'''x'''{{tt|_t}}}}<br><br><br><br> |
− | | {{vertical|{{ | + | |{{vertical|{{tt|std::int_least}}'''x'''{{lc|_t}}}} |
− | | {{vertical|{{ | + | |{{vertical|{{tt|std::int_fast}}'''x'''{{lc|_t}}}} |
− | + | |{{vertical|{{tt|std::intmax_t}}}} | |
− | + | |{{vertical|{{tt|std::intptr_t}}}} | |
|- | |- | ||
− | | | + | ! {{tt|d}} |
+ | |style="text-align:left;"|input of a signed decimal integer value | ||
+ | |SCNd'''x''' | ||
+ | |SCNdLEAST'''x''' | ||
+ | |SCNdFAST'''x''' | ||
+ | |SCNdMAX | ||
+ | |SCNdPTR | ||
|- | |- | ||
− | ! {{tt| | + | ! {{tt|i}} |
− | | | + | |style="text-align:left;"|input of a signed integer value |
− | | | + | |SCNi'''x''' |
− | | | + | |SCNiLEAST'''x''' |
− | | | + | |SCNiFAST'''x''' |
− | | | + | |SCNiMAX |
− | | | + | |SCNiPTR |
|- | |- | ||
− | ! {{tt| | + | ! {{tt|u}} |
− | | | + | |style="text-align:left;"|input of an unsigned decimal integer value |
− | | | + | |SCNu'''x''' |
− | | | + | |SCNuLEAST'''x''' |
− | | | + | |SCNuFAST'''x''' |
− | | | + | |SCNuMAX |
+ | |SCNuPTR | ||
|- | |- | ||
− | ! {{tt| | + | ! {{tt|o}} |
− | | style="text-align:left;" | input of an unsigned | + | |style="text-align:left;"|input of an unsigned octal integer value |
− | | | + | |SCNo'''x''' |
− | | | + | |SCNoLEAST'''x''' |
− | | | + | |SCNoFAST'''x''' |
− | | | + | |SCNoMAX |
− | | | + | |SCNoPTR |
|- | |- | ||
− | ! {{tt| | + | ! {{tt|x}} |
− | + | |style="text-align:left;"|input of an unsigned hexadecimal integer value | |
− | + | |SCNx'''x''' | |
− | + | |SCNxLEAST'''x''' | |
− | + | |SCNxFAST'''x''' | |
− | + | |SCNxMAX | |
− | + | |SCNxPTR | |
− | + | ||
− | + | ||
− | | style="text-align:left;" | input of an unsigned | + | |
− | | SCNx'''x''' | + | |
− | | SCNxLEAST'''x''' | + | |
− | | SCNxFAST'''x''' | + | |
− | | SCNxMAX | + | |
− | | SCNxPTR | + | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
|} | |} | ||
+ | <!-- note: SCNX* macros listed in [c.files] of C++11 and C++14 do not exist; they were an editorial error corrected in a post-C++14 standard draft --> | ||
+ | ===Notes=== | ||
+ | Because C++ interprets a character immediately following a string literal as a [[cpp/language/user literal|user-defined string literal]], C code such as {{c|printf("%"PRId64"\n",n);}} is invalid C++ and requires a space before {{tt|PRId64}}. | ||
+ | |||
+ | The C99 standard suggests that C++ implementations should not define the above limit, constant, or format macros unless the macros {{c|__STDC_LIMIT_MACROS}}, {{c|__STDC_CONSTANT_MACROS}} or {{c|__STDC_FORMAT_MACROS}} (respectively) are defined before including the relevant C header ({{tt|stdint.h}} or {{tt|inttypes.h}}). This recommendation was not adopted by any C++ standard and was removed in C11. However, some implementations (such as glibc 2.17) try to apply this rule, and it may be necessary to define the {{tt|__STDC}} macros; C++ compilers may try to work around this by automatically defining them in some circumstances. | ||
+ | |||
+ | {{tt|std::int8_t}} may be {{c/core|signed char}} and {{tt|std::uint8_t}} may be {{c/core|unsigned char}}, but neither can be {{c/core|char}} regardless of its signedness (because {{c/core|char}} is not considered a "signed integer type" or "unsigned integer type"). | ||
+ | |||
+ | ===Example=== | ||
+ | {{example | ||
+ | |See also a [[cpp/language/user_literal#Notes|note]] regarding spaces before [[#Format macro constants|format macros]] used in this example. | ||
+ | |code= | ||
+ | #include <cinttypes> | ||
+ | #include <cstdio> | ||
+ | |||
+ | int main() | ||
+ | { | ||
+ | std::printf("%zu\n", sizeof(std::int64_t)); | ||
+ | std::printf("%s\n", PRId64); | ||
+ | std::printf("%+" PRId64 "\n", INT64_MIN); | ||
+ | std::printf("%+" PRId64 "\n", INT64_MAX); | ||
+ | |||
+ | std::int64_t n = 7; | ||
+ | std::printf("%+" PRId64 "\n", n); | ||
+ | } | ||
+ | |p=true | ||
+ | |output= | ||
+ | 8 | ||
+ | lld | ||
+ | -9223372036854775808 | ||
+ | +9223372036854775807 | ||
+ | +7 | ||
+ | }} | ||
+ | |||
+ | ===Defect reports=== | ||
+ | {{dr list begin}} | ||
+ | {{dr list item|wg=lwg|dr=2820|std=C++11|before=the requirements for optional typedef names and macros were inconsistent with C|after=made consistent}} | ||
+ | {{dr list end}} | ||
+ | |||
+ | ===References=== | ||
+ | {{ref std c++23}} | ||
+ | {{ref std|section=17.4.1|title=Header <cstdint> synopsis|id=cstdint.syn}} | ||
+ | {{ref std|section=31.13.2|title=Header <cinttypes> synopsis|id=cinttypes.syn}} | ||
+ | {{ref std end}} | ||
+ | {{ref std c++20}} | ||
+ | {{ref std|section=17.4|title=Integer types|id=cstdint}} | ||
+ | {{ref std|section=29.12.2|title=Header <cinttypes> synopsis|id=cinttypes.syn}} | ||
+ | {{ref std end}} | ||
+ | {{ref std c++17}} | ||
+ | {{ref std|section=21.4|title=Integer types|id=cstdint}} | ||
+ | {{ref std|section=30.11.2|title=Header <cinttypes> synopsis|id=cinttypes.syn}} | ||
+ | {{ref std end}} | ||
+ | {{ref std c++14}} | ||
+ | {{ref std|section=18.4|title=Integer types|id=cstdint}} | ||
+ | {{ref std|section=27.9.2|title=C library files|id=c.files}} | ||
+ | {{ref std end}} | ||
+ | {{ref std c++11}} | ||
+ | {{ref std|section=18.4|title=Integer types|id=cstdint}} | ||
+ | {{ref std|section=27.9.2|title=C library files|id=c.files}} | ||
+ | {{ref std end}} | ||
+ | |||
+ | ===See also=== | ||
+ | * [[cpp/language/types|Fundamental types]] | ||
+ | {{dsc begin}} | ||
+ | {{dsc see c|c/types/integer|Fixed width integer types|nomono=true}} | ||
+ | {{dsc end}} | ||
− | + | {{langlinks|de|es|fr|it|ja|pt|ru|zh}} | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + |
Latest revision as of 09:18, 8 February 2024
Contents |
[edit] Types
Defined in header
<cstdint> | |
int8_tint16_tint32_tint64_t (optional) |
signed integer type with width of exactly 8, 16, 32 and 64 bits respectively with no padding bits and using 2's complement for negative values (provided if and only if the implementation directly supports the type) (typedef) |
int_fast8_tint_fast16_tint_fast32_tint_fast64_t |
fastest signed integer type with width of at least 8, 16, 32 and 64 bits respectively (typedef) |
int_least8_tint_least16_tint_least32_tint_least64_t |
smallest signed integer type with width of at least 8, 16, 32 and 64 bits respectively (typedef) |
intmax_t |
maximum-width signed integer type (typedef) |
intptr_t (optional) |
signed integer type capable of holding a pointer to void (typedef) |
uint8_tuint16_tuint32_tuint64_t (optional) |
unsigned integer type with width of exactly 8, 16, 32 and 64 bits respectively (provided if and only if the implementation directly supports the type) (typedef) |
uint_fast8_tuint_fast16_tuint_fast32_tuint_fast64_t |
fastest unsigned integer type with width of at least 8, 16, 32 and 64 bits respectively (typedef) |
uint_least8_tuint_least16_tuint_least32_tuint_least64_t |
smallest unsigned integer type with width of at least 8, 16, 32 and 64 bits respectively (typedef) |
uintmax_t |
maximum-width unsigned integer type (typedef) |
uintptr_t (optional) |
unsigned integer type capable of holding a pointer to void (typedef) |
The implementation may define typedef names intN_t
, int_fastN_t
, int_leastN_t
, uintN_t
, uint_fastN_t
, and uint_leastN_t
when N is not 8, 16, 32 or 64. Typedef names of the form intN_t
may only be defined if the implementation supports an integer type of that width with no padding. Thus, std::uint24_t
denotes an unsigned integer type with a width of exactly 24 bits.
Each of the macros listed in below is defined if and only if the implementation defines the corresponding typedef name. The macros INTN_C
and UINTN_C
correspond to the typedef names int_leastN_t
and uint_leastN_t
, respectively.
[edit] Macro constants
Defined in header
<cstdint> | |
Signed integers : minimum value | |
INT8_MININT16_MININT32_MININT64_MIN (optional) |
minimum value of std::int8_t , std::int16_t , std::int32_t and std::int64_t respectively (macro constant) |
INT_FAST8_MININT_FAST16_MININT_FAST32_MININT_FAST64_MIN |
minimum value of std::int_fast8_t , std::int_fast16_t , std::int_fast32_t and std::int_fast64_t respectively (macro constant) |
INT_LEAST8_MININT_LEAST16_MININT_LEAST32_MININT_LEAST64_MIN |
minimum value of std::int_least8_t , std::int_least16_t , std::int_least32_t and std::int_least64_t respectively (macro constant) |
INTPTR_MIN (optional) |
minimum value of std::intptr_t (macro constant) |
INTMAX_MIN |
minimum value of std::intmax_t (macro constant) |
Signed integers : maximum value | |
INT8_MAXINT16_MAXINT32_MAXINT64_MAX (optional) |
maximum value of std::int8_t , std::int16_t , std::int32_t and std::int64_t respectively (macro constant) |
INT_FAST8_MAXINT_FAST16_MAXINT_FAST32_MAXINT_FAST64_MAX |
maximum value of std::int_fast8_t , std::int_fast16_t , std::int_fast32_t and std::int_fast64_t respectively (macro constant) |
INT_LEAST8_MAXINT_LEAST16_MAXINT_LEAST32_MAXINT_LEAST64_MAX |
maximum value of std::int_least8_t , std::int_least16_t , std::int_least32_t and std::int_least64_t respectively (macro constant) |
INTPTR_MAX (optional) |
maximum value of std::intptr_t (macro constant) |
INTMAX_MAX |
maximum value of std::intmax_t (macro constant) |
Unsigned integers : maximum value | |
UINT8_MAXUINT16_MAXUINT32_MAXUINT64_MAX (optional) |
maximum value of std::uint8_t , std::uint16_t , std::uint32_t and std::uint64_t respectively (macro constant) |
UINT_FAST8_MAXUINT_FAST16_MAXUINT_FAST32_MAXUINT_FAST64_MAX |
maximum value of std::uint_fast8_t , std::uint_fast16_t , std::uint_fast32_t and std::uint_fast64_t respectively (macro constant) |
UINT_LEAST8_MAXUINT_LEAST16_MAXUINT_LEAST32_MAXUINT_LEAST64_MAX |
maximum value of std::uint_least8_t , std::uint_least16_t , std::uint_least32_t and std::uint_least64_t respectively (macro constant) |
UINTPTR_MAX (optional) |
maximum value of std::uintptr_t (macro constant) |
UINTMAX_MAX |
maximum value of std::uintmax_t (macro constant) |
[edit] Function macros for minimum-width integer constants
INT8_CINT16_CINT32_CINT64_C |
expands to an integer constant expression having the value specified by its argument and whose type is the promoted type of std::int_least8_t , std::int_least16_t , std::int_least32_t and std::int_least64_t respectively (function macro) |
INTMAX_C |
expands to an integer constant expression having the value specified by its argument and the type std::intmax_t (function macro) |
UINT8_CUINT16_CUINT32_CUINT64_C |
expands to an integer constant expression having the value specified by its argument and whose type is the promoted type of std::uint_least8_t , std::uint_least16_t , std::uint_least32_t and std::uint_least64_t respectively (function macro) |
UINTMAX_C |
expands to an integer constant expression having the value specified by its argument and the type std::uintmax_t (function macro) |
#include <cstdint> UINT64_C(0x123) // expands to a literal of type uint_least64_t and value 0x123
[edit] Format macro constants
Defined in header
<cinttypes> |
[edit] Format constants for the std::fprintf family of functions
Each of the PRI
macros listed here is defined if and only if the implementation defines the corresponding typedef name.
Equivalent for int or unsigned int |
Description | Macros for data types | ||||
---|---|---|---|---|---|---|
std::int x_t |
std::int_least x_t |
std::int_fast x_t |
std::intmax_t |
std::intptr_t | ||
d
|
output of a signed decimal integer value | PRIdx | PRIdLEASTx | PRIdFASTx | PRIdMAX | PRIdPTR |
i
|
PRIix | PRIiLEASTx | PRIiFASTx | PRIiMAX | PRIiPTR | |
u
|
output of an unsigned decimal integer value | PRIux | PRIuLEASTx | PRIuFASTx | PRIuMAX | PRIuPTR |
o
|
output of an unsigned octal integer value | PRIox | PRIoLEASTx | PRIoFASTx | PRIoMAX | PRIoPTR |
x
|
output of an unsigned lowercase hexadecimal integer value | PRIxx | PRIxLEASTx | PRIxFASTx | PRIxMAX | PRIxPTR |
X
|
output of an unsigned uppercase hexadecimal integer value | PRIXx | PRIXLEASTx | PRIXFASTx | PRIXMAX | PRIXPTR |
[edit] Format constants for the std::fscanf family of functions
Each of the SCN
macros listed in here is defined if and only if the implementation defines the corresponding typedef name and has a suitable std::fscanf length modifier for the type.
Equivalent for int or unsigned int |
Description | Macros for data types | ||||
---|---|---|---|---|---|---|
std::int x_t |
std::int_least x_t |
std::int_fast x_t |
std::intmax_t |
std::intptr_t | ||
d
|
input of a signed decimal integer value | SCNdx | SCNdLEASTx | SCNdFASTx | SCNdMAX | SCNdPTR |
i
|
input of a signed integer value | SCNix | SCNiLEASTx | SCNiFASTx | SCNiMAX | SCNiPTR |
u
|
input of an unsigned decimal integer value | SCNux | SCNuLEASTx | SCNuFASTx | SCNuMAX | SCNuPTR |
o
|
input of an unsigned octal integer value | SCNox | SCNoLEASTx | SCNoFASTx | SCNoMAX | SCNoPTR |
x
|
input of an unsigned hexadecimal integer value | SCNxx | SCNxLEASTx | SCNxFASTx | SCNxMAX | SCNxPTR |
[edit] Notes
Because C++ interprets a character immediately following a string literal as a user-defined string literal, C code such as printf("%"PRId64"\n",n); is invalid C++ and requires a space before PRId64
.
The C99 standard suggests that C++ implementations should not define the above limit, constant, or format macros unless the macros __STDC_LIMIT_MACROS, __STDC_CONSTANT_MACROS or __STDC_FORMAT_MACROS (respectively) are defined before including the relevant C header (stdint.h
or inttypes.h
). This recommendation was not adopted by any C++ standard and was removed in C11. However, some implementations (such as glibc 2.17) try to apply this rule, and it may be necessary to define the __STDC
macros; C++ compilers may try to work around this by automatically defining them in some circumstances.
std::int8_t
may be signed char and std::uint8_t
may be unsigned char, but neither can be char regardless of its signedness (because char is not considered a "signed integer type" or "unsigned integer type").
[edit] Example
See also a note regarding spaces before format macros used in this example.
#include <cinttypes> #include <cstdio> int main() { std::printf("%zu\n", sizeof(std::int64_t)); std::printf("%s\n", PRId64); std::printf("%+" PRId64 "\n", INT64_MIN); std::printf("%+" PRId64 "\n", INT64_MAX); std::int64_t n = 7; std::printf("%+" PRId64 "\n", n); }
Possible output:
8 lld -9223372036854775808 +9223372036854775807 +7
[edit] Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 2820 | C++11 | the requirements for optional typedef names and macros were inconsistent with C | made consistent |
[edit] References
- C++23 standard (ISO/IEC 14882:2024):
- 17.4.1 Header <cstdint> synopsis [cstdint.syn]
- 31.13.2 Header <cinttypes> synopsis [cinttypes.syn]
- C++20 standard (ISO/IEC 14882:2020):
- 17.4 Integer types [cstdint]
- 29.12.2 Header <cinttypes> synopsis [cinttypes.syn]
- C++17 standard (ISO/IEC 14882:2017):
- 21.4 Integer types [cstdint]
- 30.11.2 Header <cinttypes> synopsis [cinttypes.syn]
- C++14 standard (ISO/IEC 14882:2014):
- 18.4 Integer types [cstdint]
- 27.9.2 C library files [c.files]
- C++11 standard (ISO/IEC 14882:2011):
- 18.4 Integer types [cstdint]
- 27.9.2 C library files [c.files]
[edit] See also
C documentation for Fixed width integer types
|