Difference between revisions of "cpp/types/endian"
From cppreference.com
m |
m (→See also: + byteswap) |
||
Line 56: | Line 56: | ||
little-endian | little-endian | ||
}} | }} | ||
+ | |||
+ | ===See also=== | ||
+ | {{dsc begin}} | ||
+ | {{dsc inc | cpp/numeric/dsc byteswap}} | ||
+ | {{dsc end}} | ||
{{langlinks|de|es|fr|it|ja|pt|ru|zh}} | {{langlinks|de|es|fr|it|ja|pt|ru|zh}} |
Revision as of 06:14, 7 October 2021
Defined in header <bit>
|
||
enum class endian { |
(since C++20) | |
Indicates the endianness of all scalar types:
- If all scalar types are little-endian,
std::endian::native
equalsstd::endian::little
- If all scalar types are big-endian,
std::endian::native
equalsstd::endian::big
Corner case platforms are also supported:
- If all scalar types have sizeof equal to 1, endianness does not matter and all three values,
std::endian::little
,std::endian::big
, andstd::endian::native
are the same. - If the platform uses mixed endian,
std::endian::native
equals neitherstd::endian::big
norstd::endian::little
.
Possible implementation
enum class endian { #ifdef _WIN32 little = 0, big = 1, native = little #else little = __ORDER_LITTLE_ENDIAN__, big = __ORDER_BIG_ENDIAN__, native = __BYTE_ORDER__ #endif };
Example
Run this code
Possible output:
little-endian
See also
(C++23) |
reverses the bytes in the given integer value (function template) |