我目前正在编写一个程序,该程序存储一个“uint16_t”数值数组,然后将它们写入二进制文件。由于大小考虑,我写入二进制文件(因为我将处理大量数据)。到目前为止,这是我的代码:
static int sizebuf=5;
int main(int argc, const char *argv[]){
uint16_t buff[sizebuf];
for(int i=0; i<sizebuf; i++){
buff[i]=i;
}
FILE *fpbin=fopen("test.bin","a+");
fwrite(buff, sizeof(uint16_t), sizeof(buff)/sizeof(uint16_t), fpbin);
rewind(fpbin);
uint16_t buffer[sizebuf];
fread(buff, sizeof(uint16_t), sizebuf, fpbin);
for (int i = 0; i < 5; i++)
{
printf("%" PRIu16 "\n",buffer[i]);
}
fclose(fpbin);
return 0;
}
当我使用'hexdump'检查'test.bin'中的输出时,我得到以下信息:
0000000 0000 0001 0002 0003 0004
000000a
首先,我不太确定我是否理解第一个“000000”和最后一个“00000a”值的存在。其次,我怎样才能将这些值转换回小数(即恢复为原始数值)?我咨询过的消息来源之间的共识似乎意味着没有标准的方法来做到这一点(鉴于我正在处理通用二进制输出,我理解这一点),但是我可以处理我的特定数据以进行转换的方法是什么?
谢谢您的帮助!
编辑:添加“fread”位代码后,我收到了以下输出:
5
0
10416
49150
0