数据在内存中的存储

本文详细解析了数据在内存中的存储方式,包括整型和浮点型数据的存储规则,介绍了原码、反码、补码的概念。讨论了大端字节序和小端字节序的区别,并通过练习题帮助读者理解字节序的判断。同时,文章详细阐述了浮点数在内存中的IEEE 754标准表示形式。
摘要由CSDN通过智能技术生成

深度解析数据在内存中的存储

数据类型的基本归类:

前面我们已经学习了基本的内置类型,现在咱们基本归类一下

  1. 整型家族:

char
unsigned char (无符号字符类型)
signed char (有符号字符类型)
short
unsigned short [int] (无符号字符类型)
signed short [int] (有符号字符类型)
int
unsigned int
signed int
long
unsigned long [int]
signed long [int]

  1. 浮点型家族

float
double

  1. 构造类型(自定义类型)

数组类型
结构体类型 struct
枚举类型 enum
联合类型 union

  1. 指针类型

int *p;
char *p;
float *p;
void *p;

  • 空类型(无类型) void
  • 通常应用于函数的返回类型、函数的参数、指针类型

整形在内存中的存储

一个变量的创建是要在内存中开辟空间的。
空间的大小是根据不同的类型而决定的
例如:

int a = 10;

  • 我们都知道 a 是占四个字节的空间
    那如何存储 ? 下面来了解一下

原码、反码、补码

计算机中的整数有三种2进制表示方法,即原码、反码和补码。
三种表示方法均有符号位数值位两部分,符号位都是用0表示“正”,用1表示“负”而数值位
正数的原、反、补码都相同。

负整数的三种表示方法各不相同

  • 原码
    直接将数值按照正负数的形式翻译成二进制就可以得到原码。

  • 反码
    将原码的符号位不变,其他位依次按位取反就可以得到反码。

  • 补码
    反码+1就得到补码。

整数在内存中存储的形式都是用补码

之前的操作符的详解中详细的讲过正数和负数在二进制的表示,下面有链接
链接: 操作符详解

大端字节序和小端字节序介绍

我们可以看到下面图片中 a 和 b 分别存储的是补码,是以十六进制显示的
但是我们发现顺序有点不对劲,为什么呢
在这里插入图片描述

  • 这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8 bit。由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。
  • 因此就导致了大端存储模式和小端存储模式
大端字节序

大端(存储)模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址
中;

小端字节序

小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地
址中。

在这里插入图片描述

练习题:

写一个程序来判断当前编译器的字节序

  • 思路:
    在这里插入图片描述
  • 代码实现
int main()
{
   
	int a = 1;
	char* b = (char*)&a;
	if (*b == 1)
		printf("小端\n");
	else
		
  • 30
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 25
    评论
评论 25
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值