use*_*282 5 c++ type-conversion
我目前正在处理需要使用uint8_t的项目.我发现了一个问题,有人可以向我解释为什么会这样吗?
//using DIGIT_T = std::uint8_t;
using DIGIT_T = std::uint32_t;
std::uint8_t bits = 1;
DIGIT_T test1 = ~(DIGIT_T)0;
std::cout << std::hex << (std::uint64_t)test1 << std::endl;
DIGIT_T test2 = ((~(DIGIT_T)0) >> bits);
std::cout << std::hex << (std::uint64_t)test2 << std::endl;
Run Code Online (Sandbox Code Playgroud)
在这种情况下,输出是预期的
ffffffff
7fffffff
Run Code Online (Sandbox Code Playgroud)
但是当我取消注释第一行并使用uint8_t时输出为
ff
ff
Run Code Online (Sandbox Code Playgroud)
这种行为给我带来了麻烦.
谢谢您的帮助.
马雷克
正如评论已经详细解释的那样,这是由整数提升引起的。这应该可以解决问题:
DIGIT_T test2 = ((DIGIT_T)(~(DIGIT_T)0) >> bits);
Run Code Online (Sandbox Code Playgroud)
当然可以缩短为:
DIGIT_T test2 = (DIGIT_T)~0 >> bits;
Run Code Online (Sandbox Code Playgroud)