参考博客:http://blog.youkuaiyun.com/liuyanfeier/article/details/60957171
我在hadoop中存取了10个float数据,分别为0.1 1.1……9.1 看到输出的结果是正确的,然而保存成二进制用C进行读取的时候发现数据很乱,并不是我想要的。由于输出时对的,然而C二进制读取出现问题,怀疑是java和C读取二进制的方式不同。
主要原因:在java中采用大端存储的方式,C采用小端存储的方式,换语言后应该先进行格式转换。
参考以上博客的说明,我在程序中添加了一个格式转换的模块:
float ReverseFloat(const float input)
{
float result;
char* floatToConvert = (char*)&input;
char* returnFloat = (char*)&result;
returnFloat[0] = floatToConvert[3];
returnFloat[1] = floatToConvert[2];
returnFloat[2] = floatToConvert[1];
returnFloat[3] = floatToConvert[0];
return result;
}
之后读取hadoop生成的二进制文件的结果正确。