我试图将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在我的初稿中指出一个错误。