将big endian中的有符号整数数组转换为c中little endian中的十六进制16位

convert signed integer array in big endian to hexa decimal 16 bit in little endian in c

我是字节序的新手。 我正在尝试将大端整数数组转换为小端的十六进制字符串。我试图将大端整数数组转换为小端十六进制字符串。但最后,得到大端十六进制编码的字符串而不是小端。请帮助我

gint16 frame[5] = {10, -26, 35, 7, -35};  //big endian 
gint16 frame_i[5];
size_t i;
for (i= 0; i < 5; i++) {
  frame_i[i] = (frame[i] << 8) | ((frame[i] >> 8) & 0xFF);  //big endian to little endian
}
char *str = malloc(5 * 4 + 1);
size_t j;
for (j= 0; j < 5; j++) {
    snprintf(str + j * 4, 5, "%04X", frame_i[j] & 0xFFFF); // getting big endian  instead of little endian
}

表达式 (frame_i[i] << 8) | ((frame_i[i] >> 8) & 0xFF); 无效(如果您使用了 -Wall 编译器选项,您会注意到这一点)。此外,您应该将此操作应用于 frame 变量,并将结果存储在 frame_i 中,例如:

int16_t frame[5] = {10, -26, 35, 7, -35};
int16_t frame_i[5] = {0};
size_t i;

for (i = 0; i < sizeof(frame) / sizeof(int16_t); i++) {
  frame_i[i] = (frame[i] << 8) | ((frame[i] >> 8) & 0xFF);
}

for (i = 0; i < sizeof(frame) / sizeof(int16_t); i++) {
  printf("%04X -> %04X\n", frame[i] & 0xFFFF, frame_i[i] & 0xFFFF);
}

输出

000A -> 0A00
FFE6 -> E6FF
0023 -> 2300
0007 -> 0700
FFDD -> DDFF

请注意,正如 @WeatherVane 所指出的,负符号整数的右移具有实现定义的行为。查看 this 问题的答案。考虑使用无符号类型,例如uint16_t 来自 stdint.h.