大小端存储的理解与判断方法

一,什么是大小端

计算机的数据存储方式 ,可以分为 大端存储(Big-Endian) ‌和‌小端存储(Little-Endian),不同的计算机内部采用的存储方式可能不同。

大端存储:低地址处存放 高位数据

小端存储:低地址处存放 低位数据

图例:
以小端存储为例:

1. 正常数字 1 (若为四字节)的十六进制表示 :0x 00 00 00 01 (其中 01 为最低位 ,从左往右 位数递增 )

2. 观察内存调试窗口,首先发现int a的内存数据 占用四个字节 ,具体分布是 01 00 00 00 ,

其中四个字节的地址和数据对应

A759AFFB34 01

A759AFFB35 00

​​​​​​​ ​​​​​​​A759AFFB36 00

A759AFFB37 00

便可以发现 01 作为 最低位 是 存储在 较低地址处 的 符合 小端存储

二 如何用代码判断

方法一:

将整形(int) 地址强转成 字符(char)类型 地址 ,此时 对 字符地址解引用 必定 得到 4个字节 的 首地址(低地址) 所存储的数据 ,如果为 1 则代表 低地址存储 的 为 01(小端) 否则 则存储的为 00(大端)

cpp 复制代码
#include <stdio.h>
int main()
{
	int a = 1;
	if (1 == *((char*)&a))
	{
		printf("小端存储");
	}
	else 
	{
		printf("大端存储");
	}
	return 0;
}

方法二:

运用联合体共享空间的特性

首先 KeyUn 的 总大小 为 4字节 (联合体的大小为 占用空间最大的 成员 的大小),KeyUn成员中 int a;的占用空间最大(4字节),所以 整体 KeyUn的 空间为 4 字节。

其中 char c也使用 int a对应的 相同4字节空间 ,但是没有对 c 进行赋值 ,所以 此时 查看 c的值 ,默认还是在 a 的 4 字节空间 中 的 首地址空间 取值 (即低地址处),如果为1则同理 为 小端存储。

cpp 复制代码
union UN
{
	int a;
	char c;
};
#include <stdio.h>
int main()
{
	union UN KeyUn;
	KeyUn.a = 1;
	if ((int)KeyUn.c == 1)
		printf("小端存储");
	else 
		printf("大端存储");

	return 0;
}
相关推荐
努力努力再努力wz20 小时前
【C++进阶系列】:位图和布隆过滤器(附模拟实现的源码)
java·linux·运维·开发语言·数据结构·c++
eSoftJourney20 小时前
C 语言核心关键字与数据结构:volatile、struct、union 详解
c语言·数据结构
(❁´◡`❁)Jimmy(❁´◡`❁)20 小时前
【Trie】 UVA1401 Remember the Word
算法·word·图论
小年糕是糕手21 小时前
【C语言】C语言预处理详解,从基础到进阶的全面讲解
linux·c语言·开发语言·数据结构·c++·windows·microsoft
高山有多高1 天前
从 0 到 1 保姆级实现C语言双向链表
c语言·开发语言·数据结构·c++·算法·visual studio
今后1231 天前
【数据结构】冒泡、选择、插入、希尔排序的实现
数据结构·算法·排序算法
草莓熊Lotso1 天前
《算法闯关指南:优选算法--滑动窗口》--14找到字符串中所有字母异位词
java·linux·开发语言·c++·算法·java-ee
hhhhhshiyishi1 天前
WLB公司内推|招联金融2026届校招|18薪
java·算法·机器学习·金融·求职招聘
---学无止境---1 天前
九、内核数据结构之list
linux·数据结构·list
MATLAB代码顾问1 天前
Python实现手榴弹爆炸算法(Grenade Explosion Method, GEM)(附完整代码)
开发语言·python·算法