我试图将char数组转换为uint64_t数组,但它不起作用。
这是我的代码:

char input[8];
//Initialisation of input
int i,j;
uint64_t paquet=0;
for(i = 0; i < 8; i++)
{
    for(j = 0; j < 8; j++)
    {
        paquet+= (input[i] >> j) & 0x01;
        paquet = paquet << 1;
    }
}

最佳答案

假设input缓冲区将数据存储在一个小的endian表示中,这意味着最低有效字节位于最低地址,最高有效字节位于最高地址,那么您可以执行如下操作。

#include <stdio.h>

#define __STDC_FORMAT_MACROS
#include <inttypes.h>

int main(void)
{
    int i;
    unsigned char input[8] = {0x01, 0x02, 0x03, 0x04, 0x5, 0x06, 0x07, 0x08 };
    uint64_t paquet = 0;
    for( i = 7; i >= 0; --i )
    {
        paquet <<= 8;
        paquet |= (uint64_t)input[i];
    }

    printf("0x%" PRIx64 "\n", paquet);

    return 0;
}

您可以看到ideone上的工作示例。
如果缓冲区存储在big endian模式下,则反转循环。
感谢m24p在我的初稿中指出一个错误。

08-05 11:01