首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C语言之浮点数的存储

C语言中,有两种类型的浮点数:32位的float和64位的double,而在计算机中存储的是用二进制的科学计数法(即基数为2)表示的值 例如100=1100100B=1.1001B*26,123.456...既然基数固定为2,尾数的整数部分固定为1,那存储时就可以省略掉它俩了,只需要存储另外三个信息:正负符号+指数+尾数的小数部分 float:符号占1位,指数占8位,尾数小数占23位; double:符号占...1位,指数占11位,尾数小数占52位 不过指数也有正负,因此存储时加个偏移来表示。...再看一个纯小数的存储,例如0.00123456,这次倒着推导一下 ? 计算机中存储的是983683318,转换为二进制就是00111010101000011101000011110110B。...计算机里存储的是两个32位数:1079958831(高)、446676599(低) ?

1.5K11
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    浮点数在内存中的存储

    浮点数在内存中的存储 常见的浮点数: 3.14159 , 1E10等, 浮点数家族包括 : float , double , long double类型....要理解这个结果,⼀定要搞懂浮点数在计算机内部的表示方法。...例如 5.5在内存中的存储为101.1, 怎么来的呢? 请看下图小数转化为二进制在内存中的权重....浮点数取的过程 指数E从内存中取出的过程可以再分为三种情况: E不全为0不全为1 这时,浮点数就采用下面的规则表示,即指数E的计算值减去127(或1023),得到真实值,再将有效数字M前加上第⼀位的1....9以整型的形式存储在内存中,得到如下⼆进制序列: 0000 0000 0000 0000 0000 0000 0000 1001 首先,将 9 的二进制序列按照浮点数的形式拆分,得到第⼀位符号位s=0,

    6810

    浮点数在内存中的存储

    一、用科学计数法存储小数 一个小数,如5.5,它在存储进入计算机之前会先转化成科学计数法的形式,先将5.5转化为二进制形式,即101.1,接着转化成科学计数法的形式便是1.011*2²,再进一步转化为国际标准...(1)国际标准IEEE 根据国际标准 IEEE (电气和电子工程协会) 754 ,任意一个二进制浮点数 V 可以表示成下面的形式: V=(-1)^S * M * 2^E ,为什么是2^E呢?...1.00011*2³ 转IEEE,是正数,S=0,M=1.00011,E=3即(-1) ^0 *1.00011* 2^3 (套公式接下来也不写了...*2² 转IEEE,为负数S=1,M=1.10001,E=2 练习部分就结束了,相信大家对于小数转为 国际标准IEEE的形式已经有所了解,接下来进入本文的重点部分,浮点数在内存中的存储...二、浮点数在内存中的存储 浮点数数据在32位的处理器上最高的1位存放符号位(S) 接着的后

    18310

    浮点数在内存中的存储

    浮点数在内存中的存储详解 我们知道, 计算机内部实际上只能存储或识别二进制。...我们日常使用的 浮点数 也不例外, 最终也要被存储到这样的二进制小格子中。(来源于知乎) 对于整形来说:数据存放内存中其实存放的是补码。 那么,对于浮点数来说,在内存中是如何存储的呢?...,最⾼的1位存储符号位S,接着的8位存储指数E,剩下的23位存储有效数字M 对于64位的浮点数,最⾼的1位存储符号位S,接着的11位存储指数E,剩下的52位存储有效数字M 下面用图来理解以下上述的IEEE...例如,2^10的E是10,所以保存成32位浮点数时,必须保存成10+127=137,即10001001 保存如下 此外,指数E还有一个重点,不能存储为全0或者全1!...好了,阿豪今天的分享就到这了,点个关注不迷路哦!

    9110

    浮点数在内存中的存储

    常见的浮点数:3.14159、1E10等,浮点数家族包括: float、double、long double 类型。...浮点数表示的范围: float.h 中定义 根据国际标准IEEE(电气和电子工程协会)754,任意一个二进制浮点数V可以表示成下面的形式:  V  =  (−1) ^S*M ∗ 2^ E •  M表示符号位...IEEE 754规定: 对于32位的浮点数,最高的1位存储符号位S,接着的8位存储指数E,剩下的23位存储有效数字M 对于64位的浮点数,最高的1位存储符号位S,接着的11位存储指数E,剩下的52...位存储有效数字M   浮点数存的过程 IEEE 754 对有效数字M和指数E,还有一些特别规定。         ...,就成了 0.000000  9以整型的形式存储在内存中,得到如下二进制序列: 0000 0000 0000 0000 0000 0000 0000 1001 首先,将 9 的二进制序列按照浮点数的形式拆分

    15910

    整数和浮点数在内存中存储

    整数在内存中的存储: 整数的2进制表⽰⽅法有三种,即原码、反码和补码整数的2进制表⽰⽅法有三种,即原码、反码和补码。...浮点数在内存中的存储: #include int main() { int n = 9; float* pFloat = (float*)&n; printf("n的值为:%...下面我们就来详细的讲讲浮点数在内存中的存储。 要理解这个结果,⼀定要搞懂浮点数在计算机内部的表⽰⽅法。...对于32位的浮点数,最⾼的1位存储符号位S,接着的8位存储指数E,剩下的23位存储有效数字M 对于64位的浮点数,最⾼的1位存储符号位S,接着的11位存储指数E,剩下的52位存储有效数字M我们就可以有如下的图来表示...9以整型的形式存储在内存中,得到⼆进制序列: 1 0000 0000 0000 0000 0000 0000 0000 1001 ⾸先,将 9 的⼆进制序列按照浮点数的形式拆分,得到第⼀位符号位s=0,

    6810

    整数和浮点数在内存中存储

    整数在内存中的存储         整数的二进制以 原码 反码 补码 表示.        ...00001000         补码:00001000           -8的存放         原码:10001000         反码:11110111         补码:11111000  浮点数在内存中的存储...        常见的浮点数 1.23 1E5等,浮点数家族包括:float double long double   ( 它们的范围在float.h中定义)         它们的存储按照 IEEE754...101.0 = 1.01 * 2^2                -5.0 = -101.0 = -1 * 1.01 * 2 ^ 2         由IEEE 754规定         32位的浮点数这样储存...         64位的浮点数这样储存 注意 :           在对E存储的时候,要加上中间值127,然后表示成二进制码储存 而储存M的时候,尾数要去整数部分,然后补齐0到23位

    10910

    数据在内存中的存储——浮点数

    那么到这我们就应该想一下,到底是为什么,难道是之前对于整型的存储的理解到浮点数就不同了?难不成浮点数的存储方式,和我们想的完全不一样吗?...那么,S=1,M=1.01,E=2 同时IEEE754规定: 1、对于32位的浮点数来说,最高位的1位存储的是符号位S,接着的8位存储指数E,剩下的23位存储有效数字M。...2、对于64位的浮点数来说,最高位的1位存储的是符号位S,接着的11位存储指数E,剩下的52位存储有效数字M。...其实,由于n是整型,所以在存储的时候就会是32个比特,会是 0000 0000 0000 0000 0000 0000 0000 1001 那么变为浮点数的时候,第一位是S=0,E=0此时应该是上面的...E全为0的时候,应该是一个很小的数字,所以才会导致最后的结果是0.0000000 看第二部分 既然是浮点数的指针,那么存储的时候会是什么呢?

    24310

    整数和浮点数在内存中的存储

    3.浮点数在内存中的存储 先看下面一段代码的输出结果是什么?...对于上面的问题,其实就是关于浮点数在内存中的存储方式。下面就来讲讲浮点数在内存中究竟是如何存储的。...3.1浮点数的存储 根据国际标准IEEE(电⽓和电⼦⼯程协会) 754,任意⼀个⼆进制浮点数V可以表示成下面的形式: • (−1)S 表示符号位,当S=0,V为正数;当S=1,V为负数 • M 表示有效数字...IEEE 754规定: 对于32位的浮点数,最高的1位存储符号位S,接着的8位存储指数E,剩下的23位存储有效数字M 对于64位的浮点数,最高的1位存储符号位S,接着的11位存储指数E,剩下的52位存储有效数字...首先看9是如何存储在内存中的 0000 0000 0000 0000 0000 0000 0000 1001 然后,将 9 的⼆进制序列按照浮点数的形式拆分,得到第一位符号位s=0,后面8位的指数

    18010

    整数与浮点数在内存中的存储

    整形数据类型的存储(通常存的是二进制的补码) 大端(存储)模式:是指数据的低位字节内容保存在内存的高地址处,而数据的高位字节内容,存储在内存的低地址处。...浮点数在内存中的存储 浮点数家族成员:float,double,long double类型。...整数与浮点数在内存中的存储是有区别的,下面我们具体来看看浮点数的存储方式: #include int main() { int n = 9; float *pFloat = (float...IEEE754规定: 对于32位的浮点数,最⾼的1位存储符号位S,接着的8位存储指数E,剩下的23位存储有效数字M  对于64位的浮点数,最⾼的1位存储符号位S,接着的11位存储指数E,剩下的52位存储有效数字...⽐如,2^10的E是 10,所以保存成32位浮点数时,必须保存成10+127=137,即10001001。 值得一提的是,由于浮点数的特殊存储方式,浮点数在内存中有可能存在无法精确存储的问题。

    14910

    杂谈c语言——6.浮点数的存储

    1.浮点数在内存中的存储 常⻅的浮点数:3.14159、1E10等,浮点数家族包括: float、double、long double 类型。...答案是: 1.2 浮点数的存储 上⾯的代码中, num 和 *pFloat 在内存中明明是同⼀个数,为什么浮点数和整数的解读结果会差别 这么⼤?...就相当于(-1)的0次方*1.011*10的2次方 所以: S==0; M==1.011; E==2; 浮点数的存储,就是存储S,M,E相关的值 !!!!!!...IEEE754规定: 1.对于32位的浮点数,最⾼的1位存储符号位S,接着的8位存储指数E,剩下的23位存储有效数字M                                                 ...float类型浮点数内存分配 2.对于64位的浮点数,最⾼的1位存储符号位S,接着的11位存储指数E,剩下的52位存储有效数字M

    22010

    整数和浮点数在内存中的存储

    char类型为一个字节,以char类型为例; 有符号整形signed char取值范围:-128~127; 无符号整形unsigned char 取值范围:0~255; 浮点数在内存中的储存...浮点数的存储 浮点数的表示方式: V:(-1)^s*M*2^E 例:3.5二进制表示(-1)^0*1.11*2^1 s=0,M=1.11,E=1 (-1)^s:表示符号位,当s=0时,V为正数...,当s=1时,V为负数; M :表示有效数字,取值范围为1<=M<2; 2^E:表示指数位 浮点数的储存就是与S、M、E相关的值 ​​​E754 IEEE754规定 对于32位浮点数(float):最高的一位存储的符号位...S,接着的8位存储指数E,剩下的23位存储有效数字M 对于64位浮点数(double):最高的一位存储的符号位S,接着的11位存储指数E,剩下的52位存储有效数字M E是无符号整形 E为8位时,取值范围为...0~255; E为11位时,取值范围为0~2047; 但在科学计数法中,E可以是负数,所以要加上一个中间值,8位的中间值为127,11位的中间值为1023 浮点数读取的过程 E不全为0或不全为1时:指数

    8810

    MySQL的存储过程_MySQL创建存储过程

    delimiter 指定SQL语句的结束符 存储过程中的变量 在MySQL中,变量一般可分为分为三种类型: 系统变量、用户定义变量、局部变量; 一、系统变量 系统变量是MySQL服务器系统自身提供的...注意点: mysql服务重新启动之后,所设置的全局参数会失效,要想不失效,可以在 /etc/my.cnf 中配置; 全局变量(GLOBAL): 全局变量针对于所有的会话; 会话变量(SESSION):...循环语句在编程中经常被用到,常用于对批量的数据进行循环处理,在mysql的存储过程中,也提供了几种常用的循环语句,包括:while循环,repeat循环,和loop循环; 1、while循环语句 while...END WHILE; 先判定条件,如果条件为true,则执行逻辑,否则,不执行逻辑 需求:从1累加到N,并求出累加的结果 create procedure p6(in n int) begin...本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

    22.3K21

    MySQL:MySQL 存储过程

    MySQL 存储过程(了解) 1 什么是存储过程 MySQL 5.0 版本开始支持存储过程 存储过程(Stored Procedure)是一种在数据库中存储复杂程序,以便外部程序调用的一种数据 库对象。...存储过程是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可通过 指定存储过程的名字并给定参数(需要时)来调用执行。 简单理解: 存储过程其实就是一堆 SQL 语句的合并。...中间加入了一些逻辑控制 2 存储过程的优缺点 优点:   存储过程一旦调试完成后,就可以稳定运行,(前提是,业务需求要相对稳定,没有变化)   存储过程减少业务系统与数据库的交互,降低耦合...,数据库交互更加快捷(应用服务器,与 数据库服务器不在同一个地区) 缺点:    在互联网行业中,大量使用MySQL,MySQL的存储过程与Oracle的相比较弱,所以较少使用,并且互联网行业需求变化较快也是原因之一...goods; END $$ 3) 调用存储过程 语法格式 call 存储过程名 -- 调用存储过程 查询goods表所有数据 call goods_proc; 方式2 1) IN 输入参数:表示调用者向存储过程传入值

    16.1K10

    MySQL浮点数与定点数

    在MySQL中float和double用来表示浮点数。 ? 定点数不同于浮点数,定点数实际上是以字符串形式存放,所以定点数可以更精确地保存数据。...如果实际插入的数值精度大于实际定义的精度,则MySQL会进行警告(默认的SQLMode下),但是数据按照实际精度四舍五入后插入;如果SQLMode是在TRADITIONAL(传统模式)下,则系统会直接报错...在MySQL中,decimal(或numberic)用来表示定点数。 ? ---- 浮点数与定点数的区别,看一个例子 ? ? ?...因此在精度要求比较高的应用中(比如货币)要使用定点数而不是浮点数来保存数据 在今后关于浮点数和定点数的应用中,需要考虑到以下几个原则 浮点数存在误差问题 对货币等,对精度敏感的数据,应该用定点数表示或存储...在编程中,如果用到浮点数,要特别注意误差问题,并尽量避免做浮点数比较 要注意浮点数中一些特殊值的处理

    1.3K20

    C语言-整数与浮点数:内存存储的差异

    整数与浮点数在内存中的存储机制 在计算机科学中,整数和浮点数是我们经常处理的两种数据类型。它们在内存中的存储方式决定了它们可以表示的范围、精度以及如何进行数学运算。...整数在内存中的存储 整数在内存中的存储通常使用二进制补码形式。二进制补码是一种表示整数的方法,它使得加法和减法操作变得简单,因为这两种操作在二进制补码形式下可以共享相同的电路。...浮点数在内存中的存储 浮点数的存储要复杂得多,因为它们需要表示小数点和指数的变化。在计算机中,浮点数通常遵循IEEE 754标准,这是一种广泛接受的浮点数表示方法。...由于浮点数的表示方式,它们并不能精确地表示所有的实数。例如,0.1在二进制浮点数中只能是一个近似值,这可能导致在进行浮点数运算时出现舍入误差。...总结 了解整数和浮点数在内存中的存储机制是理解计算机如何处理这些数据的基础。整数主要使用二进制补码形式表示,而浮点数则遵循IEEE 754标准,使用符号位、指数位和尾数位来表示。

    11010

    【C语言进阶】内存中浮点数的存储规则

    二、 浮点数在内存中的存储是怎样的 2.1 引例 浮点数的存储规则: 举例来说: 有效数字M和指数E的特别规定 验证浮点数是不是这样存储的 2.2 指数E的三种情况 (1) E不全为0或不全为1 (2)...但是你们知道在内存中是怎么存储的吗? 一、什么叫做浮点数? 在生活中我们常见的浮点数: 3.14 1E10 这种科学计数法:由于小数点可以左右移动,所以我们称为浮点数。...接下来就要了解一下浮点数的存储方式大家就明白了。...5.5的存储是不是我们上面代码计算那样 这时我们可以看到内存中的确是按这种方法存储的 由于在这里是小端存储所以16进制是反着存的 2.2 指数E的三种情况 (1) E不全为0或不全为1 这时,浮点数就采用下面的规则表示...什么是浮点数 浮点数的存储规则 浮点数在内存中的存储模型 在IEEE 电气电子工程师协会中关于 指数E 和 有效数字M的规定 指数E的3种情况 希望大家有所收获呢。

    25810
    领券