这是显示intel然后在ARM中相同程序的输出的图像:
http://screencast.com/t/1eA64D4rF
两者都显示读取二进制文件的输出,其中第一列中的数字为双精度浮点格式。为什么在ARM环境中我无法获得正确的结果(例如intel-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上正确处理双精度数字?
像41784.998495和-8.1974E + 204之类的数字之间的差异很可能是字节排序问题-Intel处理器为低位优先级,而ARM为高位优先级。因此,如果您在一个文件上写了一个二进制文件,而在另一个文件上想读它,则需要对这些值进行字节交换。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句