读取并提取32位无符号整数的特定位数

本文关键字:定位 无符号整数 提取 32位 读取 | 更新日期: 2023-09-27 17:49:18

如何在c++/C中读取和提取32位无符号整数的特定位数?然后,结果值转换为浮点数。

例如

:32整数0xC0DFCF19 for x=读取11位,y=读取11位,for z =读取32位整数的最后10位。提前感谢!

好吧!非常感谢所有的答案,非常有帮助!

有人可以给出一个示例代码如何以类似的方式读取这个整数0x7835937C,但"y"应该是334 (x,z保持不变)谢谢

读取并提取32位无符号整数的特定位数

下面是一个示范程序

#include <iostream>
#include <iomanip>
#include <cstdint>
int main() 
{
    std::uint32_t value = 0xC0DFCF19;
    std::uint32_t x = value & 0x7FF;
    std::uint32_t y = ( value & ( 0x7FF << 11 ) ) >> 11;
    std::uint32_t z = ( value & ( 0x3FF << 22 ) ) >> 22;
    std::cout << "value = " << std::hex << value << std::endl;
    std::cout << "x = " << std::hex << x << std::endl;
    std::cout << "y = " << std::hex << y << std::endl;
    std::cout << "z = " << std::hex << z << std::endl;
    return 0;
}

程序输出为

value = c0dfcf19
x = 719
y = 3f9
z = 303

如果需要,可以将变量x, y, z声明为浮点数

一般的想法是使用按位布尔运算和移位运算符>>来屏蔽部分位,将这些位移动到所需的位置。特别是&操作符允许您保留特定的位,并将其他所有位设置为零。在y的示例中,您需要从输入的32位中屏蔽位11-21,如:

input  xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
& with 00000000000111111111110000000000
=      00000000000xxxxxxxxxxx0000000000
shift by 10 bits to the right
=      000000000000000000000xxxxxxxxxxx

因为你不能用C风格写位,你必须把位掩码转换成十六进制。

到浮点数的转换是隐式处理的,当你给它赋值一个双精度或浮点数变量时,假设你想把整数值(例如5)转换为浮点数(例如5.0)。

假设您的位被划分为

xxxxxxxxxxxyyyyyyyyyyyzzzzzzzzzz

,你想要双重结果,你的例子将如下:

int v = 0; //input
double x = v >> 21;
double y = (v & 0x1FFC00) >> 10;
double z = v & 0x3FF;