一、判断系统是32位或64位
32位处理器一次只能处理32位,也就是4个字节的数据,虚拟地址空间的最大值是4G。
64位处理器一次能处理64位,也就是8个字节的数据,虚拟地址空间的最大值是16T。
32位处理器:系统指针(32位 ),long(32位),int(32位),short(16位)
64位处理器:系统指针(64位 ),long(64位),int(32位),short(16位)
#include <stdio.h>
int main()
{
void *ptr = 0;
printf("%d\n", sizeof(ptr));
}
gcc以__i386__来进行32位编码,以__x86_64__来进行64位编码。
#include <stdio.h>
int main()
{
#ifdef __x86_64__
printf("__x86_64__\n");
#elif __i386__
printf("__i386__\n");
#endif
return 0;
}
二、判断系统是大端还是小端
大端模式:字数据的高字节存储在低地址中,字数据的低字节存放在高地址中。big endian
小端模式:字数据的高字节存储在高地址中,字数据的低字节存放在低地址中。little endian
1、直接判断内存的存储情况
// 1: Little Endian; 0: Big Endian.
int isLittleEndian(void)
{
int i = 0x12345678;
char *c = (char *)&i;
return ((c[0] == 0x78) && (c[1] == 0x56) && (c[2] == 0x34) && (c[3] == 0x12));
}
2、用union方法判断
typedef union {
int i;
char c;
} myUnion;
// 1: Little Endian; 0: Big Endian.
int isLittleEndian02(void)
{
myUnion u;
u.i = 1;
return (u.i == u.c);
}
读取成员c就相当于是读取成员a的低位的第一个字节值。
小端模式:u.i = 1,则a的最低位字节为1,成员c的位置也是内存的最低位字节,所以u.i等于u.c等于1。