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

相关推荐
麦兜*1 小时前
Swift + Xcode 开发环境搭建终极指南
开发语言·ios·swiftui·xcode·swift·苹果vision pro·swift5.6.3
pusue_the_sun2 小时前
数据结构:二叉树oj练习
c语言·数据结构·算法·二叉树
萧鼎2 小时前
Python pyzmq 库详解:从入门到高性能分布式通信
开发语言·分布式·python
艾伦~耶格尔3 小时前
【集合框架LinkedList底层添加元素机制】
java·开发语言·学习·面试
yujkss3 小时前
Python脚本每天爬取微博热搜-终版
开发语言·python
yzx9910133 小时前
小程序开发APP
开发语言·人工智能·python·yolo
啊阿狸不会拉杆4 小时前
《算法导论》第 32 章 - 字符串匹配
开发语言·c++·算法
曙曙学编程5 小时前
stm32——GPIO
c语言·c++·stm32·单片机·嵌入式硬件
武当豆豆5 小时前
C++编程学习(第25天)
开发语言·c++·学习
-Xie-7 小时前
Maven(二)
java·开发语言·maven