0

我正在位移一个符号整数第一个字节是指数接下来的 4 是尾数。这似乎并不总是有效,我相信这是因为将其称为字符,但是当我将其设为有符号或无符号字符时,它仍然不是 100%。有任何想法吗?

 char mdentrypxexp[1];    
 memcpy( mdentrypxexp, message + pos, 1 );
 int32_t MDEntryPxExp = mdentrypxexp[0]; 
 std::cout <<  "MDEntryPxExp  " << MDEntryPxExp << std::endl;
 pos+=1;

 char mdentrypxmantissa[4];    
 memcpy( mdentrypxmantissa, message + pos, 4 );

 int32_t MDEntryPxMantissa = mdentrypxmantissa[0] | ( (int32_t)mdentrypxmantissa[1] << 8 ) | (int32_t)mdentrypxmantissa[2] << 16 ) | ( (int32_t)mdentrypxmantissa[3] << 24 ); 
 std::cout << "MDEntryPxMantissa  " << MDEntryPxMantissa << std::endl;
 pos+=4;

 double MDEntryPx = MDEntryPxMantissa * pow10(MDEntryPxExp);
 std::cout << " MDEntryPx=" << MDEntryPx; 
4

1 回答 1

0

您正在从 4 个带符号的 int32_t 构建带符号的 int32_t。向上转换 2 的补码有符号整数会使按位运算变得棘手。使用无符号整数,然后进行转换。

uint32_t MDEntryPxMantissa_tmp = ( static_cast< uint32_t >( mdentrypxmantissa[0] ) | ( static_cast< uint32_t >( mdentrypxmantissa[1] ) << 8 ) | static_cast< uint32_t >( mdentrypxmantissa[2] ) << 16 ) | ( static_cast< uint32_t >( mdentrypxmantissa[3] ) << 24 ) ); 
int32_t MDEntryPxMantissa = *reinterpret_cast< int32_t * >( &MDEntryPxMantissa_tmp );
于 2014-12-17T21:52:16.870 回答