【大端和小端存储】C语言


前言

我们先通过一道题来引入大端和小端的概念,如下所示

请简述大端字节序和小端字节序的概念,设计一个小程序来判断当前机器的字节序。


一、大端和小端的概念。

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

1.对大端和小端的具体解释

我们知道数据在计算机中的存储方式是以补码的形式存储的(对补码不理解的可以看这篇文章位操作符的介绍),如整形数据2,在内存中的储存形式是
0000 0000 0000 0000 0000 0000 0000 0010,我们将二的补码转换为一个十六进制数,则为00 00 00 02
但当我们在VS 2022的环境下调试时,发现其内存中储存的数字2的十六进制位如下图:
数字2在内存中的形式
在上图中可以看到数字2在内存中的储存形式为02 00 00 00,正好与我们在上文计算出的00 00 00 02次序相反,但也不是每一位都是相反的如20 00 00 00的形式,这是因为在内存中我们的数据是以字节为一个整体进行存储的,并且我们的IDE:VS 2022是以小端的形式进行存储,即高位放在高地址,低位放在低地址。

二.写程序判断当前机器的字节序

#define _CRT_SECURE_NO_WARNINGS 1
#include <iostream>
using namespace std;
int main()
{
    
    
	int a = 1;
	char* p = (char*)&a;//用char型的指针访问a的首地址,如果拿到的是01则是小端,如果是00则是大端
	if (*p == 0)
	{
    
    
		cout << "大端存储" << endl;
	}
	else if (*p == 1)
	{
    
    
		cout << "小端储存" << endl;
	}
	return 0;
}

运行结果如下所示:
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_63614711/article/details/128558009