gpt4 book ai didi

c++ - 无法将十六进制数据转移到无符号长整型中

转载 作者:行者123 更新时间:2023-11-30 16:08:49 25 4
gpt4 key购买 nike

我正在尝试将 IEEE 754 浮点表示转换为其十进制等效值,因此我有一个示例数据 [7E FF 01 46 4B CD CC CC CC CC CC 10 40 1B 7E],其格式为十六进制.

char strResponseData[STATUS_BUFFERSIZE]={0};

unsigned long strData = (((strResponseData[12] & 0xFF)<< 512 ) |((strResponseData[11] & 0xFF) << 256) |((strResponseData[10] & 0xFF)<< 128 ) |((strResponseData[9] & 0xFF)<< 64) |((strResponseData[8] & 0xFF)<< 32 ) |((strResponseData[7]& 0xFF) << 16) |((strResponseData[6] & 0xFF )<< 8) |(strResponseData[5] & 0xFF));

value = IEEEHexToDec(strData,1);

然后我将这个值传递给这个函数

IEEEHexToDec(unsigned long number, int isDoublePrecision)
{
int mantissaShift = isDoublePrecision ? 52 : 23;
unsigned long exponentMask = isDoublePrecision ? 0x7FF0000000000000 : 0x7f800000;
int bias = isDoublePrecision ? 1023 : 127;
int signShift = isDoublePrecision ? 63 : 31;

int sign = (number >> signShift) & 0x01;
int exponent = ((number & exponentMask) >> mantissaShift) - bias;

int power = -1;
double total = 0.0;
for ( int i = 0; i < mantissaShift; i++ )
{
int calc = (number >> (mantissaShift-i-1)) & 0x01;
total += calc * pow(2.0, power);
power--;
}
double value = (sign ? -1 : 1) * pow(2.0, exponent) * (total + 1.0);

return value;
}

但作为返回,我得到的值是 0,而且当我尝试打印 strData 时,它只给我 CCCCCD。我正在使用 Eclipse IDE。请我需要一些建议

最佳答案

((strResponseData[12] & 0xFF)<< 512 )

首先,<<运算符需要多个位进行移位,您似乎将其与乘以所得的二的幂相混淆 - 虽然它具有相同的效果,但您需要提供指数。鉴于您没有 512 位宽度的典型数据类型,因此相当肯定实际上应该是这样。

((strResponseData[12] & 0xFF)<< 9 )

接下来,在进行转换之前,要转换的值必须具有足够的类型来保存结果。一个char显然是不够的,因此您需要在执行转换之前显式地将值转换为足够的类型以保存结果。

另外请记住,根据您的平台,unsigned long可能是 32 位或 64 位类型,因此如果您正在执行位移位操作,而结果不适合 32 位,您可能需要使用 unsigned long long或者更好的是让事情变得明确,例如 #include <stdint.h>并输入如 uint32_tuint64_t 。鉴于您的问题被标记为“嵌入式”,记住这一点尤其重要,因为您可能面向 32 位(甚至 8 位)处理器,但有时会构建算法来在开发计算机上进行测试。

此外,一个 char可以是有符号或无符号类型。在转移之前,你应该明确这一点。鉴于您要组合某些内容的多个部分,几乎可以肯定,至少其中的大部分应该被视为无符号。

所以你可能想要类似的东西

((uint32_t)(strResponseData[12] & 0xFF)<< 9 )

除非你在一个奇怪的平台上 char不是 8 位(例如某些 TI DSP),您可能不需要使用 0xff 进行预屏蔽,但这不会损害任何内容

<小时/>

最后,你并不是 100% 清楚你在盯着什么:

i have an example data [7E FF 01 46 4B CD CC CC CC CC CC 10 40 1B 7E] which is in hex.

模棱两可,因为不清楚您的意思

[0x7e, 0xff, 0x01, 0x46...]

这将是一个字节值数组,为了方便起见,调试代码已以十六进制打印出来,或者如果您实际上的意思是诸如

"[7E FF 01 46 .... ]"

哪个文本字符串包含人类可读的十六进制数字表示形式作为可打印字符。在后一种情况下,您首先必须将十六进制数字或八位字节的字符表示形式转换为数值。

关于c++ - 无法将十六进制数据转移到无符号长整型中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59252407/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com