C语言整数和浮点数在内存中的存储

目录

一.整数在内存中的存储

整数在内存中是以二进制的补码存储的
正整数的源码 反码 补码 都一样,首位的符号位为0
负整数的三种表示形式各不相同

负整数的符号位为1

源码:直接把二进制翻译过来

反码:符号位不变,其他位按位取反

补码:反码+1

补码找回源码也是取反,加一

二.浮点数在内存中的存储

浮点数V,S表示符号位,S为0,V为正数,S为1,V为负数 M为有效数字,M>=1&&M<2

E为指数位.

10进制的5.5的浮点数表示为:101.1,根据国际标准I E

EE为:(-1)^0 * 1.011 * 2^2,S=0,M=1.011,E=2

举个例子:

5.5是十进制,5可以表示二进制为101,0.5必须要用浮点数的表示形式为:

浮点数分为:32位和64位浮点数。 32位浮点数(float):第一位表示符号位S,接着的8位表示的指数位E,最后的23位表示的有效数字M

64位浮点数(double):第一位是符号位S,接着的11位是指数E,52位是有效数M

1.浮点数存的过程

存入内存中
对于M

根据IEEE对有效数字M和指数E有些特殊的规定 对于M,M的表示形式为:1.XXX,XXX为小数部分

比如:64位浮点数,M保存的时候可以把第一位的符号位省去,这样读取的时候可以把符号位加上去,这样就多了一位有效数字,64位的E就可以保存53位有效数字了
存的是小数点后面的数

对于E

E的值+中间值=存入内存中的值

32位浮点数的中间值为127

64位浮点数的中间值为1023

例如:2^5:的E为5,所以保存在内存中的值(float类型)为:5+127=132(10000100)

2.浮点数取的过程

从内存中取出来

浮点数的取可以分成三种情况:

1.E不全为0或E不全为1

E的值+中间值=存入内存中的值 M再加上首位(小数点前)的1

例如:

怎么存 :0.5的表示为:(-1)^0 * 1.0*2^-1, S = 0,M = 1.0,E = -1,-1 + 127 = 126

0 01111110 00000000000000000000000

怎么取: 存入内存中的值 = 126,- 中间值 = - 127,= E的值 -1 (-1)^ 0 * 1.0 * 2 ^ -1

2.E全为0

0 00000000 0010000000000000000000
E:1-127=-126 有效数字M不再加上1,而是为:0.XXX

(-1)^0 * 1.0 * 2 ^ -129 这样就表示-+0,表示很小的数

3.E全为1

0 11111111 00100000000000000000000 (-1)^ 0 * 1.0 * 2 ^ 253

如果M全为0,表示很大的数:正负无穷 (S表示正负号)

三.浮点数的例题

9.0的二进制为:1001.0 (-1) ^ 0 * 1.001 * 2 ^ 3
S = 0
M = 1.001
E = 3
在内存中(二进制)为:
0 10000010 001000000000000000000000

0 00000000 00000000000000000001001

9.0 整型以浮点型打印:0.000000是输出的十进制

拿到是M的值,前面加上0

9.0浮点型以整型打印

0 10000010 01100000000000000000000

会打印出很大的数

这个二进制码的整数,原反补码都相同

相关推荐
Databend19 小时前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路
数据库·人工智能·agent
ClouGence2 天前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将2 天前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils3 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波3 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_4 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
zzzzzz3105 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
倔强的石头_7 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab8 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence8 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle