详细聊聊为什么Python中0.2+0.1不等于0.3
作者:阳光下的小恐龙 发布时间:2021-08-19 12:12:35
为什么Python中0.2+0.1不等于0.3
大家请看下面的python程序代码:
print(0.2+0.1)
猜一猜运行结果是什么,是0.3吗?
NoNoNo!
来看一看运行结果:
0.30000000000000004
为什么是0.30000000000000004呢?
浮点数运算
这是因为在计算机中,浮点数运算也是要先转化为二进制的
1.浮点数如何转化为二进制:
⑴整数部分:除以2,取出余数,商继续除以2,直到得到0为止,将取出的余数逆序
⑵小数部分:乘以2,然后取出整数部分,将剩下的小数部分继续乘以2,然后再取整数部分,一直取到小数部分为零为止。
如果永远不为零,则按要求保留足够位数的小数,最后一位做0舍1入。将取出的整数顺序排列。
2. 0.2转化为二进制:(只看小数点后)
0.2 × 2 = 0.4 取 0
0.4 × 2 = 0.8 取 0
0.8 × 2 = 1.6 取 1
0.6 × 2 = 1.2 取 1
0.2 × 2 = 0.4 取 0
0.4 × 2 = 0.8 取 0
0.8 × 2 = 1.6 取 1
…
所以0.2转化为浮点数为0.001100110011…(0011无限循环)0.1转化为二进制:
同理0.1转化为浮点数为0.0001100110011…(0011无限循环)
0.2+0.1
因为在计算机中,0.2和0.1都不是确定的数,而是近似值,因此它们经过浮点数运算(对阶、尾数运算、规格化处理、舍入处理、溢出处理)后得到的值也是近似值,经过了计算机的四舍五入。所以结果是0.30000000000000004
附:实现0.1+0.2==0.3
在python中有一个模块decimal可以解决0.1+0.2!=0.3的问题。
decimal模块提供了一个Decimal数据类型用于浮点数的计算,相比于内置的二进制浮点数计算更加精确。
简单的使用方法:给decimal传递Decimal整型或者字符串类型,但不能是浮点数据(浮点数据本身不准确)
来源:https://blog.csdn.net/qq_52067365/article/details/123055674


猜你喜欢
- 讲解1、库:os,shutil.copy2、代码效果:对指定文件夹内文件等量分配到新的文件夹3、代码原理:用os.listdir()遍历文件
- itchat模块官方参考文档:https://itchat.readthedocs.io/zh/latest/安装pip install i
- CREATE DATABASE `ct` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_c
- 我们在用爬虫对门户网站进行模拟登录是总会有输入图片验证码的,例如这种那我们怎么解决这个问题实现全自动的模拟登录呢?只要思想不滑坡,办法总比困
- 1. 函数求一阶导import tensorflow as tftf.enable_eager_execution()tfe=tf.cont
- 利用pygame实现了简易版飞机大战。源代码如下:# -*- coding:utf-8 -*-import pygameimport sys
- 高能预警本文包含演示部分,请读者自行copy代码编译体验。参考资料:sync.WaitGroup / signal.Notify / con
- 第一种方法: /* 创建链接服务器 */ exec sp_addlinkedserver 'srv_lnk','
- 在TP5公共common.php文件里写<?php //计算某个类别所属的类别层数 function getcatelayer($ca
- 场景go 如果频繁地创建、销毁对象(比如 http 服务的 json 对象,日志内容等),会对 GC 造成压力。比如下面的 Log 函数,在
- 本文实例讲述了PHP利用header跳转失效的解决方法,分享给大家供大家参考。具体方法分析如下:一、问题:今天header(\"L
- 本文实例讲述了PHP接口多继承及tarits实现多继承效果的方法。分享给大家供大家参考,具体如下:接口多继承在PHP的面向对象中,接口可以继
- MySql 这个数据库绝对是适合dba级的高手去玩的,一般做一点1万篇新闻的小型系统怎么写都可以,用xx框架可以实现快速开发。可是数据量到了
- 将Django与其他现有认证系统的用户名和密码或者认证方法进行整合是可以办到的。例如,你所在的公司也许已经安装了LDAP,并且为每一个员工都
- 深度学习网络通常具有很深的层次结构,而且层与层之间通常会有并联、串联等连接方式。当使用PyTorch建立一个深度学习网络并输出文本向读者展示
- 想跟大家聊聊关于 mysql 中的两个小的知识点:redo log 和 binlog 。redo log :InnoDB 存储引擎层方面的日
- 1、汇总统计介绍几个聚集函数有多少名学生SELECT COUNT(*) FROM student;SELECT COUNT(1) FROM
- OpenCV 是一个C++库,目前流行的计算机视觉编程库,用于实时处理计算机视觉方面的问题,它涵盖了很多计算机视觉领域的模块。在P
- Celery是一个异步的任务队列(也叫做分布式任务队列),一个简单,灵活,可靠的分布式系统,用于处理大量消息,同时为操作提供维护此类系统所需
- 如果你之前没用过进度条,八成是觉得它会增加不必要的复杂性或者很难维护,其实不然。要加一个进度条其实只需要几行代码。在这几行代码中,我们可以看