写一个C程序判断系统是32或64位、大端或小端字节序

一、判断系统是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

int main()

{

void *ptr = 0;

printf("%d\n", sizeof(ptr));

}

gcc以__i386__来进行32位编码,以__x86_64__来进行64位编码。

#include

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。

随便看看