当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 8 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : C++中浮点数比较的奇怪问题
帖子发表于 : 2011-04-02 21:16 
头像

注册: 2010-04-02 16:44
帖子: 528
系统: openSUSE 13.2 x64
送出感谢: 2
接收感谢: 11
在C语言中,浮点数是不能用“==”进行比较的,所以我想在C++中也是一样。但是今天偶然蛋疼地写了一下浮点数的比较,发现竟然能直接用“==”比较。各位牛人们,敢问这是为神马?
以下是测试程序:

#include <iostream>
#include <cstdlib>
using namespace std;

int main()
{
double a = 3.1;

if (a == 3.1)
{
cout << "yes" << endl;
}
else
{
cout << "no" << endl;
}
return 0;
}


_________________
正在建设中的个人博客


页首
 用户资料  
 
2 楼 
 文章标题 : Re: C++中浮点数比较的奇怪问题
帖子发表于 : 2011-04-03 10:58 
头像

注册: 2010-12-31 12:11
帖子: 43
送出感谢: 0 次
接收感谢: 0 次
qgymib 写道:
在C语言中,浮点数是不能用“==”进行比较的,所以我想在C++中也是一样。但是今天偶然蛋疼地写了一下浮点数的比较,发现竟然能直接用“==”比较。各位牛人们,敢问这是为神马?
以下是测试程序:

#include <iostream>
#include <cstdlib>
using namespace std;

int main()
{
double a = 3.1;

if (a == 3.1)
{
cout << "yes" << endl;
}
else
{
cout << "no" << endl;
}
return 0;
}
数的逻辑对比全部是通过暂存运算加上运算产生的标志位影响来判断的,整数的格式化很简单,每个整数如果不溢出都有一个标准的表示,而浮点数在存储的时候有一个向格式化域趋近存储的过程。相同的浮点数也能保证存储的时候趋近存储相同。


_________________
Shane_Wayne
Let's go to a new world!


页首
 用户资料  
 
3 楼 
 文章标题 : Re: C++中浮点数比较的奇怪问题
帖子发表于 : 2011-04-03 12:20 
头像

注册: 2006-07-02 11:16
帖子: 12522
地址: 廣州
送出感谢: 0 次
接收感谢: 8
谁说不能用 ==


_________________
^_^ ~~~
要理解递归,首先要理解递归。

地球人都知道,理论上,理论跟实际是没有差别的,但实际上,理论跟实际的差别是相当大滴。


页首
 用户资料  
 
4 楼 
 文章标题 : Re: C++中浮点数比较的奇怪问题
帖子发表于 : 2011-04-03 21:12 
头像

注册: 2010-04-02 16:44
帖子: 528
系统: openSUSE 13.2 x64
送出感谢: 2
接收感谢: 11
zx0319 写道:
qgymib 写道:
在C语言中,浮点数是不能用“==”进行比较的,所以我想在C++中也是一样。但是今天偶然蛋疼地写了一下浮点数的比较,发现竟然能直接用“==”比较。各位牛人们,敢问这是为神马?
以下是测试程序:

#include <iostream>
#include <cstdlib>
using namespace std;

int main()
{
double a = 3.1;

if (a == 3.1)
{
cout << "yes" << endl;
}
else
{
cout << "no" << endl;
}
return 0;
}
数的逻辑对比全部是通过暂存运算加上运算产生的标志位影响来判断的,整数的格式化很简单,每个整数如果不溢出都有一个标准的表示,而浮点数在存储的时候有一个向格式化域趋近存储的过程。相同的浮点数也能保证存储的时候趋近存储相同。


但是,为什么使用float类型的时候就不能使用“==”进行比较呢?


_________________
正在建设中的个人博客


页首
 用户资料  
 
5 楼 
 文章标题 : Re: C++中浮点数比较的奇怪问题
帖子发表于 : 2011-04-03 23:03 
头像

注册: 2009-07-25 1:57
帖子: 701
送出感谢: 5
接收感谢: 13
这个是实现相关的,而且浮点的保留精度还和你编译器开启的浮点选项有关。各种不同的编译器默认的浮点选项可能会有很大差别的,比如intel的c++编译器(默认开了-fp-model fast)和gcc默认的精度相差蛮大的。
最好不要直接比较浮点数,要比较的话,也应该使用现成的库,比如写测试的话(一般程序控制里需要比较浮点往往说明程序写的有问题,真要写这种比较建议先去翻你用的编译器手册,不要觉得这种是无关痛痒的事,那是你没吃过苦头。),应该使用google test 里专门的浮点比较宏,可以保证在给定绝对误差范围内给出一致结果。


_________________
https://github.com/tangboyun
http://tangboyun.is-programmer.com/
提问的智慧————Eric Steven Raymond
回答的智慧————Andrew Clarke
吾尝终日而思矣,不如须臾之所学也;吾尝跂而望矣,不如登高之博见也。
急急急标题什么的,最讨厌了!
急急复急急,急急何其多,我生待急急,万事急急急。


页首
 用户资料  
 
6 楼 
 文章标题 : Re: C++中浮点数比较的奇怪问题
帖子发表于 : 2011-04-04 15:01 
头像

注册: 2006-07-02 11:16
帖子: 12522
地址: 廣州
送出感谢: 0 次
接收感谢: 8
qgymib 写道:
zx0319 写道:
qgymib 写道:
在C语言中,浮点数是不能用“==”进行比较的,所以我想在C++中也是一样。但是今天偶然蛋疼地写了一下浮点数的比较,发现竟然能直接用“==”比较。各位牛人们,敢问这是为神马?
以下是测试程序:

#include <iostream>
#include <cstdlib>
using namespace std;

int main()
{
double a = 3.1;

if (a == 3.1)
{
cout << "yes" << endl;
}
else
{
cout << "no" << endl;
}
return 0;
}
数的逻辑对比全部是通过暂存运算加上运算产生的标志位影响来判断的,整数的格式化很简单,每个整数如果不溢出都有一个标准的表示,而浮点数在存储的时候有一个向格式化域趋近存储的过程。相同的浮点数也能保证存储的时候趋近存储相同。


但是,为什么使用float类型的时候就不能使用“==”进行比较呢?



float 的问题是这样的,你那个 3.1 是个 double,如果 a 是初始化成 3.1 的 float 的话,比较时再提升到 double 当然跟原版的 3.1 不完全一样。。。
如果 a 是个 double,那两个 double 的 3.1 当然是一样的。。


_________________
^_^ ~~~
要理解递归,首先要理解递归。

地球人都知道,理论上,理论跟实际是没有差别的,但实际上,理论跟实际的差别是相当大滴。


页首
 用户资料  
 
7 楼 
 文章标题 : Re: C++中浮点数比较的奇怪问题
帖子发表于 : 2011-04-09 19:17 
头像

注册: 2008-07-30 23:21
帖子: 13427
地址: freebuilder@yeah.net
系统: Debian stable AMD64
送出感谢: 38
接收感谢: 127
== 比较是非常精确的比较,精确到浮点的精度。浮点比较是个灵活的问题,主要看需求,看需要多高的精度。网上那些各种比较方法只能参考,不能硬套。要更具需求写代码。
比如说,一个控制系统,对某参数设计精度为小数点后三位,则
代码:
if (abs(x1-x2) <= 0.001)

过高的精度会因起过敏甚至错误。等你见多了就知道了。


_________________
(2015-11-16 更新)适合 WM 的截图脚本
(2015-08-24 更新)Debian、Ubuntu 源列表说明
(2013-02-01 首发)文字如何绘出
▷▷ 【更 多 在 此】 ◁◁
箪食瓢饮随遇安,不求栋梁求参天。
【初韵】一门牛逼的编程语言。


页首
 用户资料  
 
8 楼 
 文章标题 : Re: C++中浮点数比较的奇怪问题
帖子发表于 : 2011-04-09 20:28 
头像

注册: 2010-04-02 16:44
帖子: 528
系统: openSUSE 13.2 x64
送出感谢: 2
接收感谢: 11
:em11 多谢楼上各位的细心回答。
现在基本了解了浮点数的比较规则。正在学习google test,争取达到传说中的牛人级别 :em04


_________________
正在建设中的个人博客


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 8 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:Bing [Bot] 和 2 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译