| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> C++知识库 -> 【C语言】浮点数的秘密 -> 正文阅读 |
|
[C++知识库]【C语言】浮点数的秘密 |
IEEE 754 标准存储方式:符号位,指数,尾数
以 float 为例,讨论浮点数。 浮点类型与整数类型的内存表示方法不同,浮点类型的内存表示法相对复杂。 根据 IEEE 754 标准,float 将自身 32bits 分成三个部分,符号位 S 占 1bit,指数 E 占 8bits,尾数 M 占 23bits。 下面用一个共用体讨论 float 类型的内存表示。
浮点数计算公式: 举个例子:已知机器码 f.v = 0x41360000,求真值 f.f。
代码验证:
输出:
不精确的类型在有限的位数里,浮点类型比 uint32_t 表达了更大的范围,导致部分数据丢失,不能表示所有准确的数值,是一种不精确的类型。 比如开区间 (338291141358099960719503586036763590656.0,339620349071475272940736969149792649216.0)中,至少有 4202553 个整数皆不能正常表示。
输出:
浮点型数据越接近零值,误差越小,反之越大。 验证通过两个简单的程序验证这个结论。 这个 C 程序的作用是增加机器码间隔采样对应的浮点数,并打印到表格文件中。
这个 python 文件的作用是读取表格文件,描点作图。
可见,当机器码增加到一定程度时,浮点数值开始指数级变化,这就表示在两个相邻的机器码之间,跨越、丢失的浮点数越多。 交流微信公众号:物联指北 |
|
C++知识库 最新文章 |
【C++】友元、嵌套类、异常、RTTI、类型转换 |
通讯录的思路与实现(C语言) |
C++PrimerPlus 第七章 函数-C++的编程模块( |
Problem C: 算法9-9~9-12:平衡二叉树的基本 |
MSVC C++ UTF-8编程 |
C++进阶 多态原理 |
简单string类c++实现 |
我的年度总结 |
【C语言】以深厚地基筑伟岸高楼-基础篇(六 |
c语言常见错误合集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/11 3:45:49- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |