计算机中数据的存储有两种方式:大端存储与小端存储
①对于存储在计算机中的数据,其是以十六进制保存的,而对于一个十六进制数:
0x00 00 00 01,从左向右位权依次降低,即:左边为高位权,右边是低位权。
②我们规定从左向右地址依次增高,即:左边为高地址,右边为低地址。
以前面的前提条件为基础,我们可以引出大端存储模式的概念:
将高位权的数字放置于低地址,将低位权的数字放置在高位置。
而与其相反的则是小端存储模式:
将低位权的数字放置于低地址,将高位权的数字放置于高地址。
而根据这一特性我们也不难推测出整形数据 1 在内存中的表达方式:
0x 00 00 00 01 自左向右,位权降低
根据上述的定义我们也不难推测出在内存中的存储方式:
对于判断大小端的方式,我们采取两种方法:
1.顺次访问字节法 2.联合体法
顺次访问字节法:#includevoid 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; }
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)