java C读取二进制文件方式

本文解决从Hadoop存储的float数据在C语言中读取出现乱码的问题,原因是Java使用大端存储而C默认为小端存储。通过实现一个简单的字节序转换函数,成功实现了跨语言的数据一致性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参考博客: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生成的二进制文件的结果正确。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值