| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1074 人关注过本帖
标题:[求助]求助“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
快速回复:[求助]求助“32位系统和64位系统的double不一致”问题!!
数据加载中...
 
   



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

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