字节排序函数
2016-07-26 20:35
274 查看
考虑一个16位的整数,它由2个字节组成。内存中存储这两个字节有两种方法:一种是将低字节存储在起始地址,这称为小端字节序;另一种方法是将高序字节存储在起始地址,这称为大端字节序。下面的程序可以检测是大端存储还是小端存储:
#include <stdio.h> int main(int argc, char *argv[]) { union
{ unsigned short num; unsigned char arr[sizeof(short)]; }test; test.num = 0x0102; if (sizeof(short) == 2) { if (test.arr[0] == 1 && test.arr[1] == 2) printf("big endian\n"); else if (test.arr[0] == 2 && test.arr[1] == 1) printf("little endian\n"); else printf("unknown\n"); } else printf("sizeof(short) = %d\n",sizeof(short)); exit(0); }
相关文章推荐
- 如何组织构建多文件 C 语言程序(二)
- 如何写好 C main 函数
- Tomcat端口被占用解决方法(不用重启)
- Mootools 1.2教程 函数
- autoit InputBox 函数
- IE7降低内存和降低CPU的几个技巧
- 文件遍历排序函数
- “传奇”图象数据存储方式
- 关于C#中排序函数的总结
- Oracle 函数大全[字符串函数,数学函数,日期函数]第1/4页
- ASP下经常用的字符串等函数参考资料
- PostgreSQL教程(五):函数和操作符详解(1)
- 如何高效的使用内存
- DOS下内存的配置
- DOS批处理 函数定义与用法
- asp Chr 函数 数字转字母的方法
- Lua中的函数精讲笔记
- Lua中的闭合函数、非全局函数与函数的尾调用详解
- Lua中调用C++函数示例
- Lua和C语言的交互详解