判断大端存储与小端存储方式

计算机中数据的存储有两种方式:大端存储与小端存储

①对于存储在计算机中的数据,其是以十六进制保存的,而对于一个十六进制数:

0x00 00 00 01,从左向右位权依次降低,即:左边为高位权,右边是低位权。

②我们规定从左向右地址依次增高,即:左边为高地址,右边为低地址。

以前面的前提条件为基础,我们可以引出大端存储模式的概念:

将高位权的数字放置于低地址,将低位权的数字放置在高位置。

而与其相反的则是小端存储模式:

将低位权的数字放置于低地址,将高位权的数字放置于高地址。

而根据这一特性我们也不难推测出整形数据 1 在内存中的表达方式:

0x 00 00 00 01 自左向右,位权降低

根据上述的定义我们也不难推测出在内存中的存储方式:

判断大端存储与小端存储方式

对于判断大小端的方式,我们采取两种方法:

1.顺次访问字节法 2.联合体法

顺次访问字节法:

#include<stdio.h>
void system_check(int a)
{
	if (*((char*)&a) == 1)
	{
		printf("小端存储");
	}
	else
	{
		printf("大端存储");
	}
}

int main()
{
	int test = 1;
	system_check(test);
	return 0;
}

这一方法的核心步骤在于if的判断条件:*((char*)&a)

我们不妨分开来进行分析:

首先取出a的地址,即为:&a

对于整型a,其占四个字节。使用指针进行解引用操作时,自然也是每次顺次访问四个字节,而以整型指针的身份进行解引用无法得知其存储方式。

我们不妨将&a强制类型转换为char类型,在接下来的每一次解引用都只能向后访问一个字节。此时即为:(char*)&a

然后我们进行解引用操作,对地址进行访问。此时即为:*((char*)&a)

以四个字节访问,我们无法判断存储方式;但以一个字节访问,我们不难看出二者的差别:

对于大端存储,直到访问到最后一个字节,通过解引用操作才能找的1;而对于小端存储,在访问到第一个字节时我们就可以发现它就是1。

联合体法:

联合体是一种结构,其存在的意义主要就是尽可能地节省内存空间;为了节省空间,其可以接受两个不同类型的元素在内存空间上的重叠。

在内存空间上可以表示为:

判断大端存储与小端存储方式

 对于联合体法的具体方法就是先对整型赋值,再对其字符类型元素解引用,看其是不是1.

代码如下:

union un
{
	char a;
	int b;
};

int main()
{
	union un u;
	u.b = 1;
	if (u.a == 1)
	{
		printf("小端存储");
	}
	else
	{
		printf("大端存储");
	}
    return 0;
}

上一篇:2014年10月行政组织理论考前密卷03319


下一篇:云服务器appid和appsecret生成