[求助]求助“32位系统和64位系统的double不一致”问题!!
在下碰到一个按说该是经典问题的问题。
简单说——
我做了一个处理程序,读入二进制文件,处理后输出的结果也是二进制文件。
但是,同样的输入文件——
我在32位系统下(比如说Windows2000,vs6.0)编译出来的exe
与在64位系统下(WindowsXP64,vs2005)编译出来的exe
其执行结果有不同。
这种不同还是比较普遍存在的。
目前听说64位系统下三角函数的返回值会和32位系统下不一致,如——
64:asin(0.99826595544498342000) = 1.51189732954303360000
32:asin(0.99826595544498342000) = 1.51189732954303380000
另外,“硬写”的数值在内存里的表示也会不同,如——
double a = 0.140855304805605;
32:3FC2078B EFCDD902
64:3fc2078b efcdd903
我向各位求助有以下几个级别的愿望,各位能帮到哪一级都感激不尽:
1)想找一个工具,或方法,当我用二进制文件浏览器看到不同的地址内容时,如何把它们还原成double型变量的数值(昨天偶尔发现金山游侠里有对地址内容各类型解释的功能,不过总不至于只能用这个吧…… Orz)
2)这种32位-64位double误差现象应该是全世界程序员都得面对的问题吧,所有这类现象的成因都有哪些,最好是没有遗漏官方资料可以让我的用户心服口服。
另外这种误差是否都是局限在很小的范围内,比如1e-16以内的浮动。
我想这个问题应该有很多前辈精英解决过,只不过小人平时见识太少查不到资料。