2.58:判断机器是大端法还是小端法
这道题思路很明确,无非就是构造一个高位字节跟低位字节不同的数字,检验机器低位(或高位)输出的是什么来判断是大端法还是小端法。
自己的代码:
int is_little_endian() {
int i = 1;
return (0xFF) & i;
}
网上看到的利用union的方法,其实字符串可以当做字节流来使用。union中数据的读取是从低位开始的。
int is_little_endian() {
union {
int a;
char b;
} un;
un.a = 1;
return un.b;
}
最后是书上的,利用类似于 show_bytes 字节数组的方法。
int is_little_endian(void) {
/* MSB = 0, LSB = 1*/
int i = 1;
/* Return MSB when big-endian, LSB when little-endian*/
return (int)(*(unsigned char *) (&i));
}
强制类型转换在系统级编程时是很常用的技巧。