对于a来讲
其二进制原码反码补码相同
00000000 00000000 00000000 00010100
转化为十六进制
00 00 00 14
而在计算机内存中却以
14 00 00 00
的形式存在
此时就涉及到大小端存储模式
大小端介绍
大端存储模式:是指数据的低位保存在内存的高地址中,而高位保存在内存的低地址中
小端存储模式:是指数据的地位保存在内存的低地址中,而高位保存在内存的高地址中
那为什么存在大小端
这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为 8bit。 但是在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器),另外,对于位数大于 8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的问题。
那如何判断当前机器的存储模式
对于a来讲,只需要判断它的第一个字节所存的数是否与本身相等,如果相等,则为小端,否则为大端存储模式;
那又要如何查看它的第一个字节呢
int类型四个字节、char类型一个字节,只需在取地址时强制转化为char类型即可
int a=1;
char *p=(char *)&a;
//如果不加(char *)则会出现警告
完整代码
#include <stdio.h>
int check_sys()
{
int a = 1;
char *p = (char *)&a;
return *p;
}
int main()
{
int ret=check_sys();
if (ret == 1)
printf("小端");
else
printf("大端");
return 0;
}