(C语言)数据在内存中的储存

目录

1>.存储的方式

2>.关于用%d来打印char类型数

3>.不同类型能表示的范围

4>.浮点数在内存中的存储

储存方式

E在内存中的存储

E在内存中的取出

1)E不全是0和1

2)E全为0

3)E全为1


整数和浮点数在内存中是以二进制的方式进行储存,有原码,反码,补码三种形式;在内存中是以补码的方式进行储存的,在操作符中有详细讲解;(C语言)操作符(全网最全,最详细)-CSDN博客

1>.存储的方式

存储的方式分为两种:大端字节序存储,小端字节序存储;

大端字节序存储:将一个数据的低位字节内容存放在高地址处,高位字节内容存放在低地址处;

小端字节序存储:将一个数据的高位字节内容存放在高地址处,低位字节内容存放在低地址处;

vs整形运用的是小端字节序存储;

总结来说就是:正着放是大端,反着放是小端;

2>.关于用%d来打印char类型数

注意:前面补位补的是什么;

3>.不同类型能表示的范围

相当于一个循环

unsigned char类型因为没有符号位,所以它的范围是0-255;

short类型是:-32768-32767;

注意:char a=0其实a储存的是ASCII码值为0的字符;

4>.浮点数在内存中的存储

5.5的二进制就是101.1,其中的1和0都是二进制,0.1表示2^(-1);

举例来说:5.5=(-1)^0*1.011*2^2

注意:因为小数都是2的(-n)次方相加得到的,所以在储存的时候浮点数可能不能精确储存;

储存方式

M可以写成1.xxxxxx,其中xxxxxx是小数部分,在计算机内部保存M的时候,默认这个数的第一位是1,因此可以舍去,不用保存,只保存后面的xxxxxx,比如:1.01只保存01,等到读取的时候,再把第一位的1加上就可以了,这样可以节省一个比特位,让M可以多占用一个比特位;

E在内存中的存储

为了保证在内存中E的储存是一个正数,对应于32位机器,我们需要加上一个中间量127;也就是-5在内存中是-5+127=122,就是0111 0000;

E在内存中的取出

1)E不全是0和1

指数在取出的时候,计算值减去127(或1023),得到真实值,再将有效值数值M前加上一位1;

2)E全为0

减去127(或1023)或是2^(-127)是一个接近于0的很小的数字,当作0看

3)E全为1

其表示+(-)127,看作一个无穷大的数;

相关推荐
FL16238631293 小时前
[C#][winform]基于yolov8的水表读数检测与识别系统C#源码+onnx模型+评估指标曲线+精美GUI界面
开发语言·yolo·c#
cnxy1885 小时前
围棋对弈Python程序开发完整指南:步骤1 - 棋盘基础框架搭建
开发语言·python
sevenez6 小时前
Vibe Coding 实战笔记:从“修好了C坏了AB”到企业级数据库架构重构
c语言·笔记·数据库架构
程序员-周李斌7 小时前
Java 死锁
java·开发语言·后端
一路往蓝-Anbo7 小时前
【第20期】延时的艺术:HAL_Delay vs vTaskDelay
c语言·数据结构·stm32·单片机·嵌入式硬件
JasmineWr7 小时前
CompletableFuture相关问题
java·开发语言
零雲7 小时前
java面试:知道java的反射机制吗
java·开发语言·面试
Jeremy爱编码7 小时前
实现 Trie (前缀树)
开发语言·c#
laocooon5238578868 小时前
插入法排序 python
开发语言·python·算法
你的冰西瓜8 小时前
C++中的list容器详解
开发语言·c++·stl·list