Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >C语言(浮点精度)

C语言(浮点精度)

作者头像
用户2617681
发布于 2019-08-08 08:04:17
发布于 2019-08-08 08:04:17
1.8K0
举报
文章被收录于专栏:秘籍酷秘籍酷

关于C语言的浮点数精度问题,很多人存在误解,他们往往认为精度指的是float、double和long double三种数据类型,这是片面的。

拓展:

浮点数的二进制存储细节:

对于每个不同的浮点数,都有相应的最小可辨识精度(即δ),此最小可辨识精度随着该浮点数的数值变化而变化,具体究竟是多少要具体分析该浮点数的二进制存储内部细节,找到其指数域之后才能确定,我们根据这个最小可辨识精度才能明确判定代码中所有对此浮点数的运算是否有效,否则可能会由于舍入的问题存在而在逻辑上存在歧义。

下面的代码完美诠释了以上结论:

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-07-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 秘籍酷 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
[c语言日寄]浮点数的排序
在C语言的编程实践中,浮点数的排序是一个常见且重要的问题。无论是科学计算、数据分析还是图形处理,我们常常需要对浮点数数组进行排序。然而,浮点数的排序并不像整数排序那样简单直接,因为浮点数的精度问题和特殊值(如NaN和无穷大)需要特别处理。
siy2333
2025/03/17
820
浮点数在计算机中是如何表示的
相比int等整型,float等浮点类型的表示和存储较为复杂,但它又是一个无法回避的话题,那么就有必要对浮点一探究竟了。在计算机中,一般用IEEE浮点近似表示任意一个实数,那么它实际上又是如何表示的呢?
编程珠玑
2019/09/02
2K0
js浮点数精度问题详解
浮点数精度问题是指在计算机中使用二进制表示浮点数时,由于二进制无法精确表示某些十进制小数,导致计算结果可能存在舍入误差或不精确的情况。
can4hou6joeng4
2023/11/17
7510
C语言中的浮点数存储:深入探讨
由此可知,C语言中浮点数的存储方式和整数的存储方式是不同的,下面就让我们详细了解一下。
平凡之路.
2024/10/09
2380
C语言中的浮点数存储:深入探讨
小朋友学C语言(43):浮点数的深入分析
IEEE二进制浮点数算术标准(IEEE 754)是20世纪80年代以来最广泛使用的浮点数运算标准,为许多CPU与浮点运算器所采用。这个标准定义了表示浮点数的格式(包括负零-0)与反常值(denormal number)),一些特殊数值(无穷∞与非数值NaN),以及这些数值的“浮点数运算符”。 IEEE 754规定了四种表示浮点数值的方式:单精确度(32位)、双精确度(64位)、延伸单精确度(43比特以上,很少使用)与延伸双精确度(79比特以上,通常以80位实现)。只有32位模式有强制要求,其他都是选择性的。大部分编程语言都有提供IEEE浮点数格式与算术,但有些将其列为非必需的。例如,IEEE 754问世之前就有的C语言,现在有包括IEEE算术,但不算作强制要求 C语言的float通常是指IEEE单精确度,而double是指双精确度。
海天一树
2019/03/06
2K0
小朋友学C语言(43):浮点数的深入分析
浮点数精度问题透析:小数计算不准确+浮点数精度丢失根源
之前自己答的不是满意(对 陈嘉栋的回答 还是满意的),想对这个问题做个深入浅出的总结
周陆军
2019/05/17
3K0
C语言-整数与浮点数:内存存储的差异
在计算机科学中,整数和浮点数是我们经常处理的两种数据类型。它们在内存中的存储方式决定了它们可以表示的范围、精度以及如何进行数学运算。了解这些基本概念对于理解计算机如何处理这些数据以及优化相关代码至关重要。
小志biubiu
2025/02/27
1450
深入理解C++中的浮点数:内存模型、精度损失原理与提升方法
浮点数(float 和 double)在C++中被广泛用于处理需要小数表示的计算问题。然而,由于浮点数基于二进制表示,存在许多容易被忽略的陷阱,比如精度损失和比较问题。本文将详细介绍浮点数的内存模型、精度损失的根源、浮点数比较技巧以及提高精度的实用方法。
码事漫谈
2024/12/26
2850
深入理解C++中的浮点数:内存模型、精度损失原理与提升方法
[C语言]初始数据类型
💖 作者简介:大家好,我是泽奀。全栈领域新星创作者🥇作者周榜:65 ✨ 📝 个人主页:weixin_52632755的博客_泽奀_CSDN博客 💬 本系列:【C】系列_泽奀的博客-CSDN博客 🎉 点赞➕评论➕收藏 == 养成习惯😋 目录 ✉概括 🎨数据类型 char类型 ASCll码 整形类型 整数 浮点数 float类型和double类型 sizeof 语法: 数据类型字节 字节 ✉概括 数据类型其实就是: 声明不同类型的变量或者函数的一个广泛的系统。 变量的类型决定了变量存储占用的空间,
謓泽
2022/12/12
2990
[C语言]初始数据类型
IEEE二进制浮点数算术标准(IEEE 754)
IEEE二进制浮点数算术标准(IEEE 754)是20世纪80年代以来最广泛使用的浮点数运算标准,为许多CPU与浮点运算器所采用。这个标准定义了表示浮点数的格式(包括负零-0)与反常值(denormal number)),一些特殊数值(无穷(Inf)与非数值(NaN)),以及这些数值的“浮点数运算符”;它也指明了四种数值舍入规则和五种例外状况(包括例外发生的时机与处理方式)。
用户7886150
2021/02/12
1.5K0
C语言浮点数float类型的秘密
我们在学习 C 语言时,通常认为浮点数和小数是等价的,并没有严格区分它们的概念,这也并没有影响到我们的学习,原因就是浮点数和小数是绑定在一起的,只有小数才使用浮点格式来存储。
小林C语言
2020/12/16
4.9K0
C语言浮点数float类型的秘密
浮点数在计算机中的精度问题
不论大家使用的是什么编程语言想必都知道浮点数在计算机中存在一定的精度问题,特别是有float类型的编程语言中,大部分编程都是建议直接使用更高精度的double类型。下面我做的示例都以python为主。
不知名小白
2025/01/09
1560
浮点数精度不再是困扰:Python高手的精准编程秘籍!解决Python浮点数精度问题!
这里的问题在于,0.1 和 0.2 在二进制中都是无限循环小数,计算机只能存储它们的近似值。当这两个近似值相加时,结果也是一个近似值,这个近似值可能并不完全等于我们期望的十进制结果。
小白的大数据之旅
2024/11/20
2680
[c语言日寄]浮点数在内存中的储存
在计算机科学中,浮点数是一种用于表示实数的数据类型。与整数不同,浮点数可以表示非常大或非常小的数值,并且能够处理小数部分。然而,浮点数在内存中的存储方式与整数有很大的不同,本文将深入探讨浮点数在内存中的存储方式,帮助读者更好地理解这一概念。
siy2333
2025/02/07
1150
[c语言日寄]浮点数在内存中的储存
浮点数加法引发的问题:浮点数的二进制表示
1、问题: 之前有同学问过这样一个问题: echo|awk '{print 3.99 -1.19 -2.80}' 4.44089e-16 类似的问题还有在 java 或者 javascript 中: 23.53 + 5.88 + 17.64 = 47.05 23.53 + 17.64 + 5.88 = 47.050000000000004 为什么结果不是 0 或者不相等呢? 如果你不能立马回答出原因,那说明你对浮点数计算的基本知识还不了解。 刚好最近  segmentfault.co
用户1177713
2018/02/24
1.9K0
【C语言】数据类型
本篇文章我们要讲述的是数据类型的知识点,那么到底什么是数据类型呢。其实我们可以把"数据类型"这四个字拆开两段来。
謓泽
2023/10/16
3400
【C语言】数据类型
double浮点数运算为啥会丢失精度?
前言:在工作中,谈到有小数点的加减乘除都会想到用BigDecimal来解决,但是有很多人对于double或者float为啥会丢失精度一脸茫然。还有BigDecimal是怎么解决的?话不多说,我们开始。
王念博客
2019/07/24
4.6K0
【JS】527- 关于 JS 中的浮点计算
原文地址:http://eux.baidu.com/blog/fe/关于js中的浮点运算
pingan8787
2020/03/19
2K0
【JS】527- 关于 JS 中的浮点计算
基础篇:JAVA基本类型
正解 在java里的正确回答应该是boolean类型单独使用是4个byte,在数组里则是1个byte。但是虚拟机为什么不用byte或short代替boolean而是int,这样不是更节省内存空间?因为int对于32位处理器,一次处理的数据是32位,CPU寻址也是32位的查找,具有高效储存的特点(如果有更好的理解,大家共同交流下)
潜行前行
2020/12/11
1.2K0
基础篇:JAVA基本类型
【重学 MySQL】五十五、浮点和定点数据类型
MySQL提供了两种主要的浮点数据类型:FLOAT和DOUBLE,以及一种定点数据类型DECIMAL。
用户11332765
2024/10/28
3290
【重学 MySQL】五十五、浮点和定点数据类型
推荐阅读
相关推荐
[c语言日寄]浮点数的排序
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档