4

我有一个像这样的 char 数组的缓冲区:

char buf[4];
buf[0] = 0x82;
buf[1] = 0x7e;
buf[2] = 0x01;
buf[3] = 0x00;

我现在想将字符 2 和 3 一起读取为大端序中的 16 位无符号整数。如何使用 C(++) 标准工具执行此操作?

目前我只知道手动解决方案:

int length = but[3];
length += but[2] << 8;

这对于 16 位整数来说很容易,但我还需要解析 32 位整数,这会使事情变得有点困难。那么标准库中是否有一个功能可以为我做到这一点?

博多

4

3 回答 3

6

您可以使用ntohsand ntohl(在小端系统上):

#include <iostream>
#include <cstring>
#include <arpa/inet.h>
int main(){
    char buf[4];
    buf[0] = 0x82;
    buf[1] = 0x7e;
    buf[2] = 0x01;
    buf[3] = 0x00;
    uint16_t raw16;
    uint32_t raw32;
    memcpy(&raw16, buf + 2, 2); 
    memcpy(&raw32, buf    , 4); 
    uint16_t len16 = ntohs(raw16);
    uint32_t len32 = ntohl(raw32);
    std::cout << len16 << std::endl;
    std::cout << len32 << std::endl;
    return 0;
}

或者您可以交换字节并将其转换为适当的类型而不是移位。

于 2013-04-13T15:29:23.787 回答
0

您可以使用联合:

union conv {
    char arr[4];
    short value16[2];
    int value32;
};

conv tmp;
tmp.arr[0] = buf[0];
tmp.arr[1] = buf[1];
tmp.arr[2] = buf[2];
tmp.arr[3] = buf[3];

或 memcpy :

memcpy(&length, buf, sizeof(length))
于 2013-04-13T17:04:01.003 回答
-2

阿泰_ 更可能是最简单的解决方法。

int iResult = atoi(buf);
于 2013-04-13T15:40:56.953 回答