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

相关推荐
楼台的春风25 分钟前
【MCU驱动开发概述】
c语言·驱动开发·单片机·嵌入式硬件·mcu·自动驾驶·嵌入式
黑子哥呢?31 分钟前
安装Bash completion解决tab不能补全问题
开发语言·bash
青龙小码农37 分钟前
yum报错:bash: /usr/bin/yum: /usr/bin/python: 坏的解释器:没有那个文件或目录
开发语言·python·bash·liunx
大数据追光猿42 分钟前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
彳卸风2 小时前
Unable to parse timestamp value: “20250220135445“, expected format is
开发语言
dorabighead2 小时前
JavaScript 高级程序设计 读书笔记(第三章)
开发语言·javascript·ecmascript
风与沙的较量丶2 小时前
Java中的局部变量和成员变量在内存中的位置
java·开发语言
水煮庄周鱼鱼3 小时前
C# 入门简介
开发语言·c#
编程星空3 小时前
css主题色修改后会多出一个css吗?css怎么定义变量?
开发语言·后端·rust
软件黑马王子3 小时前
Unity游戏制作中的C#基础(6)方法和类的知识点深度剖析
开发语言·游戏·unity·c#