(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,看作一个无穷大的数;

相关推荐
VBA633742 分钟前
VBA之Word应用第四章第五节:段落Paragraph对象的属性(一)
开发语言
whltaoin42 分钟前
【Java SE】Java IO体系深度剖析:从原理到实战的全方位讲解(包含流操作、序列化与 NIO 优化技巧)
java·开发语言·nio·se·io体系
csbysj20205 小时前
jQuery 删除元素
开发语言
xxy-mm5 小时前
Javascript 中的继承
开发语言·javascript·ecmascript
quikai19817 小时前
python练习第二组
开发语言·python
AI视觉网奇7 小时前
Fatal signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr
开发语言·c++·算法
智者知已应修善业7 小时前
【输入两个数字,判断两数相乘是否等于各自逆序数相乘】2023-10-24
c语言·c++·经验分享·笔记·算法·1024程序员节
wjs20247 小时前
并查集快速合并
开发语言
free-elcmacom7 小时前
MATLAB与高等数学<1>一道曲面积分题的几何直观
开发语言·数学建模·matlab·高等数学
LaoZhangGong1237 小时前
深度学习uip中的“psock.c和psock.h”
c语言·开发语言