如何将字节从char数组转换为int

问题描述 投票:0回答:2

我想在C中的char数组中创建一个int变量。

char数组看起来像这样:

buffer[0] = 0xcf
buffer[1] = 0x04
buffer[2] = 0x00
buffer[3] = 0x00

这种转变看起来像这样

x = (buffer[1] << 8 )| (buffer[0] << 0) ;

之后x看起来像这样:

x = 0xffff04cf

现在一切都会好的,如果前两个字节不是ff。

如果我尝试这一行

x = (buffer[3] << 24 )| (buffer[2] << 16)| (buffer[1] << 8)| (buffer[0] << 0) ;

它仍然看起来

x = 0xffff04cf

即使我在04cf转换之前或之后尝试移入零,它看起来仍然是相同的。

这是正确的想法还是我做错了什么?

c arrays int shift
2个回答
3
投票

问题是您通过签名类型(可能是(签名)char)声明了buffer。当应用运算符<<时,将执行整数提升,并且当8位有符号类型中的值0xcf表示负值(即-49)时,它将保持为负值(但由更多位表示,即0xffffffcf)。请注意,-1表示为0xFFFFFFFF,反之亦然。

要解决这个问题,只需将buffer定义为

unsigned char buffer[4]

如果你不被允许改变buffer的数据类型,你可以写...

unsigned x = ( (unsigned char)buffer[0] << 8 )| ((unsigned char)buffer[1] << 4) ;

0
投票

对于像这样的任务,我喜欢使用工会,例如:

union tag_int_chars {
    char buffer[sizeof(int32_t)];
    int32_t value;
} int_chars;

int_chars.value = 0x01234567;

int_chars.buffer[0] = 0xff;

这将自动化存储器覆盖而无需移位。设置int的值并且chars已经改变了,改变了char值并且int已经改变了。

该示例将在一个小端机器上保留int值= 0x012345ff。

另一种简单的方法是使用memcpy():

#include <string.h>

char buffer[sizeof(int32_t)];
int32_t value;

memcpy(&value, buffer, sizeof(int32_t));   // chars to int
memcpy(buffer, &value, sizeof(int32_t));   // int to chars
© www.soinside.com 2019 - 2024. All rights reserved.