使用C语言设计函数判断系统大小端字节序
在计算机系统中,字节序(byte order)指的是字节在内存中存储的顺序。常见的字节序有大端字节序(Big Endian)和小端字节序(Little Endian)。
在大端字节序中,最高有效字节(Most Significant Byte,MSB,高地址)存储在最低的内存地址,最低有效字节(Least Significant Byte,LSB,低地址)存储在最高的内存地址。
而在小端字节序中,最低有效字节存储在最低的内存地址,最高有效字节存储在最高的内存地址。也就是说,小端字节序的顺序与我们日常书写数字的顺序一致。
思路:通过截断,来进行比较,如果结果为1则是小端字节序,不为则是大端字节序。
代码如下
int check_sys() { int num = 1; int a=*(char*)#//强制转化为char* 类型 发生截断,从而只能获得第一个字节位置数 return a; } int main(void) { //看两个字节 int ret = check_sys(); if (ret == 1) { printf("小端\n"); } else { printf("大端\n"); } return 0; }