这是一张图片,显示了英特尔和ARM中相同程序的输出:
http://screencast.com/t/1eA64D4rF
两者都显示读取二进制文件的输出,第一列中的数字是双精度浮点格式。为什么我无法在ARM环境中获得正确的结果(如英特尔 - 41784.998495,41784.998623)和(-8.1974E + 204f等)?
我正在使用的手臂处理器是:
Processor : ARM926EJ-Sid(wb) rev 0 (v5l)
BogoMIPS : 331.77
Features : swp half thumb fastmult edsp java
CPU implementer : 0x41
CPU architecture: 5TEJ
CPU variant : 0x0
CPU part : 0x926
CPU revision : 0
Cache type : write-back
Cache clean : cp15 c7 ops
Cache lockdown : format C
Cache format : Harvard
I size : 32768
I assoc : 1
I line length : 32
I sets : 1024
D size : 32768
D assoc : 1
D line length : 32
D sets : 1024
Hardware : MV-88fxx81
Revision : 0000
Serial : 0000000000000000
我在ARM上的编译选项:g++ -Wall SC_SCID.cpp
如何在此处理器上正确读取双精度类型?是否需要启用任何编译器选项才能正确处理ARM上的双精度数字?
答案 0 :(得分:0)
像41784.998495和-8.1974E + 204这样的数字之间的差异很可能是字节排序问题 - 英特尔处理器是小端的,而ARM是大端的。因此,如果您在一个文件上写一个二进制文件并想在另一个上读取它,那么您需要对这些值进行字节交换。
答案 1 :(得分:0)
注意:这是一个wiki答案;任何人都可以编辑。
根据wikipedia,double
的ARM softfp仿真使用了大端和小端的混合。对于整数类型,ARM926EJ的原生格式肯定是 little endian 。
在问题Would float point format be affected by big-endian and little endian?
中阅读更多内容