标题:[求助]求助“32位系统和64位系统的double不一致”问题!!
只看楼主
chenshuang1227
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2006-8-18
 问题点数:0 回复次数:0 
[求助]求助“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以内的浮动。
我想这个问题应该有很多前辈精英解决过,只不过小人平时见识太少查不到资料。

搜索更多相关主题的帖子: double 系统 
2006-08-18 08:04



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-84607-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.975099 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved