返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言深入探索浮点数的使用秘密
  • 727
分享到

C语言深入探索浮点数的使用秘密

2024-04-02 19:04:59 727人浏览 独家记忆
摘要

目录一、内存中的浮点数二、浮点数存储实例三、浮点类型的秘密四、小结一、内存中的浮点数 浮点数在内存的存储方式为:符号位,指数,尾数 类型符号位指数尾数float1位(第31位)8位(

一、内存中的浮点数

浮点数在内存的存储方式为:符号位,指数,尾数

类型符号位指数尾数
float1位(第31位)8位(第23--30位)23位(第0--22位)
double1位(第63位)11位(第52--62位)52位(第0--51位)

注:float 与 double 类型的数据在计算机内部的表示法是相同的,但由于所占存储空间的不同,其分别能够表示的数值范围和精度不同。

二、浮点数存储实例

浮点数的转换

  • 将浮点数转换成二进制
  • 用科学计数法表示二进制浮点数
  • 计算指数偏移后的值

注意:计算指数时需要加上偏移量,而偏移量的值与类型有关。

示例:对于指数6,偏移后的值如下:

float:127 + 6 -> 133

double:1023 + 6-> 1029

实数 8.25 的在内存中的 float 表示

8.25的二进制表示:1000.01 -> 1.00001 * (2 ^ 3)

  • 符号位:0
  • 指数:127 + 3 -> 130 10000010
  • 小数:00001

内存中 8.25 的 float 表示:

  • 0 10000010 00001000000000000000000 -> 0x41040000

下面看一下 8.25 是不是在内存中表示为 0x41040000 吧:

#include <stdio.h>
 
int main()
{
    float f = 8.25;
    unsigned int* p = (unsigned int*)&f;
    printf("0x%08X\n", *p);
    return 0;
}

下面为输出结果:

三、浮点类型的秘密

首先看一下 int 类型和 float 类型的范围:

int 类型的范围:[-2 ^ 31,2 ^ 31 - 1]

float 类型的范围:[-3.4 * 10 ^ 38,3.4 * 10 ^ 38]

这就出现一个问题:int 和 float 都占4个字节的内存,为什么 float 却比 int 的范围大得多呢?

解释如下:

  • float 能表示的具体数字的个数与 int 相同
  • float 可表示的数字之间不是连续的,存在间隙
  • float 只是一种近似的表示法,不能作为精确数使用
  • 由于内存表示法相对复杂,float 的运算速度比 int 慢得多

注意:double 与 float 具有相同的内存表示法,因此 double 也是不精确的。由于 double 占用的内存较多,所能表示的精度比 float 高。

下面看一段 float 类型的不精确示例代码:

#include <stdio.h>
 
int main()
{
    float f = 3.1415f;
    float fl = 123456789;
    printf("%0.10f\n", f);
    printf("%0.10f\n", fl);
    return 0;
}

下面为输出结果:

这个示例就是表示 f 和 fl 小数点的后 10 位,结果表明,float 只是一种近似的表示法,不能作为精确数使用以及float 可表示的数字之间不是连续的,存在间隙。

四、小结

  • 浮点类型与整数类型的内存表示法不同
  • 浮点类型的内存表示更复杂
  • 浮点类型可表示的范围更大
  • 浮点类型是一种不精确的类型
  • 浮点类型的运算速度较慢

到此这篇关于C语言深入探索浮点数的使用秘密的文章就介绍到这了,更多相关C语言浮点数内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: C语言深入探索浮点数的使用秘密

本文链接: https://lsjlt.com/news/146664.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C语言深入探索浮点数的使用秘密
    目录一、内存中的浮点数二、浮点数存储实例三、浮点类型的秘密四、小结一、内存中的浮点数 浮点数在内存的存储方式为:符号位,指数,尾数 类型符号位指数尾数float1位(第31位)8位(...
    99+
    2024-04-02
  • C语言深入探索递归的特点
    目录递归的认识main函数可以递归吗递归核心思想讲解递归的缺点递归的认识 基本认识: 1.首先递归的本质还是函数调用,也要形成和释放栈帧。 2.函数的调用是有成本的,这个成本在时间和...
    99+
    2024-04-02
  • C语言深入探索数据类型的存储
    目录数据类型介绍类型的基本归纳整型家族浮点数家族构造类型指针类型空类型整型在内存中的存储原码,反码,补码大小端浮点数在内存中的存储浮点数存储的规则数据类型介绍 首先,对于我们C语言中...
    99+
    2024-04-02
  • C语言深入探索动态内存分配的使用
    目录一、动态内存分配的意义二、malloc 和 free三、关于 malloc(0)四、calloc 和 realloc五、小结一、动态内存分配的意义 C语言中的一切操作都是基于内存...
    99+
    2024-04-02
  • C语言入门之浮点数
    目录浮点数的输出常用的库函数整数与浮点数的转换总结 实际开发中使用double,而不使用float 浮点数的输出 float采用%f占位符。 double采用%lf占位符。测试结果...
    99+
    2024-04-02
  • 深入探索Go语言中unsafe包的使用
    目录前言1. 什么是unsafe包2. unsafe.Pointer是什么3. 如何使用unsafe.Pointer来操作内存4. 如何避免unsafe包的内存错误和安全漏洞5. u...
    99+
    2023-05-14
    Go语言 unsafe包使用 Go语言 unsafe包 Go unsafe
  • C语言数据结构深入探索顺序表
    目录1.线性表2.顺序表2.1概念及结构2.2 接口实现2.2.1初始化2.2.2 检查容量2.2.3 顺序表打印2.2.4 顺序表尾插2.2.5 顺序表尾删2.2.6 顺序表头插2...
    99+
    2024-04-02
  • throw 语句的奥秘:深入探索 JavaScript
    引言 throw 语句在 JavaScript 中扮演着至关重要的角色,它允许开发人员显式地引发异常,从而在代码中引入控制流并处理错误。本文深入探讨 throw 语句的奥秘,包括它的工作原理、使用场景以及最佳实践。 throw 语句的语法...
    99+
    2024-03-01
    JavaScript、异常处理、throw、catch、try-catch
  • C语言浮点数怎么使用
    今天小编给大家分享一下C语言浮点数怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、内存中的浮点数浮点数在内存的存储...
    99+
    2023-06-30
  • 深入探索 CPython:Python 语言的骨干
    ...
    99+
    2024-04-02
  • C语言深入探索之单链表与typedef的用法
    目录前言详解typedef关键字含义具体使用详解单链表参数形式指针知识补充单链表形参详解单链表实战案例完整代码实现详解头插建表运行效果前言 昨天博主去本站问答贴子逛了逛,然后发现了好...
    99+
    2024-04-02
  • C语言深入探究函数的溯源
    目录一、函数的由来二、模块化程序设计三、C 语言中的模块化四、面向过程的程序设计五、声名和定义六、小结一、函数的由来 二、模块化程序设计 三、C 语言中的模块化 四、面向过程的...
    99+
    2024-04-02
  • 揭秘 Python 数据结构的奥秘:深入探索
    ...
    99+
    2024-04-02
  • C语言指针和数组深入探究使用方法
    目录1、数组参数和指针参数1.1 一维数组传参1.2 一级指针传参1.3 二维数组参数和二级指针参数1.4 野指针的问题2、函数指针3、函数指针数组4、指向函数数组的指针5、回调函数...
    99+
    2022-11-13
    C语言指针和数组 C语言指针 C语言数组
  • 深入探讨C语言中的Go语句
    在C语言中,Go语句是一种用于并发编程的特殊语句,它允许程序中的不同部分在程序执行过程中同时运行,提高程序的效率和性能。本文将深入探讨C语言中的Go语句,并提供具体的代码示例来帮助读者...
    99+
    2024-04-02
  • 深入探索canvas:揭开其丰富的元素秘密
    深入了解canvas:探秘其中的各种元素,需要具体代码示例 近年来,随着前端技术的快速发展,canvas成为了网页中不可或缺的一个重要元素。利用canvas可以实现各种有趣的效果,从简单的图形绘制到复杂的动画效果,都可以通过ca...
    99+
    2024-01-17
    Canvas 元素 深入了解
  • C语言深入探究栈的原理
    栈 压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈顶。 出栈:栈的删除操作叫做出栈。出数据也在栈顶。 栈的实现 栈的实现一般可以使用数组或者链表实现,相对而言数组的结构实现更优...
    99+
    2024-04-02
  • 深入探讨Go语言函数的使用案例
    珍惜时间,勤奋学习!今天给大家带来《深入探讨Go语言函数的使用案例》,正文内容主要涉及到等等,如果你正在学习Golang,或者是对Golang有疑问,欢迎大家关注我!后面我会持续更新相关内容的,希望...
    99+
    2024-04-04
  • 探讨C语言的那些小秘密之断言
    每次写摘要我都觉得是一件很头疼的事儿,因为我知道摘要真的很重要,它几乎直接就决定了读者的数量。可能花了九六二虎之力写出来的东西,因为摘要的失败而前功尽弃,因为绝大多数的读者看文章之前...
    99+
    2022-11-15
    C语言 断言
  • 深入探索Go语言在大数据处理中的应用
    在当今信息爆炸的时代,大数据处理已成为各行各业必不可少的一项技术。为了高效地处理庞大的数据量,程序员们纷纷寻求各种新的编程语言和工具。其中,Go语言以其高效的并发性能和简洁的语法,逐渐...
    99+
    2024-02-22
    大数据 应用 go语言 标准库
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作