C++ float与二进制的存储问题

参考链接:https://blog.csdn.net/wangyilong0516/article/details/11200623

看了上面的链接对计算机存储float的具体情况有了了解,然后脑袋一热的我就写下了如下的代码:

int a = 9;
float b = (float)a;
cout<<b<<endl;

我就在想为什么输出的b不是0.00000呢。后来又想一下C编译器不会这么蠢到(float)a这步直接把int的机器码成为float的机器码,也是符合人情。当你写出(float)a这一步的时候,C编译器把int型的机器码转换为float的机器码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++中,二进制文件的字节顺序可以是大端或小端。大端字节顺序是指高位字节存储在低地址,低位字节存储在高地址。而小端字节顺序则是相反的,低位字节存储在低地址,高位字节存储在高地址。 如果你需要在C++中读取一个大端字节顺序的二进制文件,你可以使用以下方法进行处理。首先,你需要定义一个函数来将小端字节顺序转换为大端字节顺序。你可以使用引用\[3\]中提供的ReverseByteOrder模板函数来实现这个功能。 然后,你可以使用std::ifstream类来打开二进制文件,并使用read函数来读取文件中的数据。在读取之前,你需要先读取文件中的宽度和高度,这可以通过引用\[1\]中的代码来实现。接下来,你可以使用引用\[1\]中的代码来读取二进制文件中的数据,并将其存储在一个std::vector<float>对象中。 需要注意的是,在Windows系统中,文件的绝对路径名格式为“C:\Users\Administrator\Desktop\data.txt”。然而,在C++中,由于‘\’被用作转义字符,所以在文件路径名中需要使用双反斜杠或者正斜杠来表示路径分隔符。因此,正确的文件路径名应该是“C:\\Users\\Administrator\\Desktop\\data.txt”或者“C:/Users/Administrator/Desktop/data.txt”。这可以参考引用\[2\]中提供的信息。 总结起来,如果你想在C++中读取一个大端字节顺序的二进制文件,你需要使用引用\[1\]中的代码来打开和读取文件,并使用引用\[3\]中的ReverseByteOrder函数来转换字节顺序。同时,你需要注意在文件路径名中使用双反斜杠或者正斜杠来表示路径分隔符。 #### 引用[.reference_title] - *1* *3* [c++读取二进制文件](https://blog.csdn.net/lucust/article/details/127222631)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [C++读写二进制格式文件](https://blog.csdn.net/yijudingyiwanju/article/details/77387143)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值