字节转换之大小端
来源:互联网 发布:网上卖数据 编辑:程序博客网 时间:2024/05/22 03:21
今天有个任务是将字节文件转换成整型,我是采用C#的BinaryReader.ReadInt32来直接读取的,运行结果也很顺利,整型结果是1577,但是好奇心驱使我用Ultraedit打开了源文件,但是我发现16进制存储的数组是这样的
这是什么鬼…,读取结果:
0x29060000=0*16^0+0*16^1+0*16^2+0*16^3+6*16^4+0*16^5+9*16^6+2*16^7=688259072
这和1577完全不搭嘎啊,都溢出了…
于是乎问大牛,查资料,得知这是大小端问题,我的是小端,低位存低位地址,高位存高位地址。
读取的正确结果应该是:
0x00000629=9*16^0+2*16^1+6*16^2=1577
大端:高位存在低地址,低位存在高地址;
小端:高位存在高地址,低位存在低地址;(intel的x86,ARM普遍都是属于小端)
查询自己机器到底是大端还是小端的方法也不复杂
C#自带BitConverter封装的IsLittleEndian判断
//判断大小端(BigEndian - LittleEndian, C#/Win小端,Java大端,网络传输大端) //数字或Unicode区分大小端(2的倍数的字节数) bool isLittle = BitConverter.IsLittleEndian; //数字 //方法一 int c = 97; byte[] cb = BitConverter.GetBytes(c);//小端 Array.Reverse(cb);//反转成大端 //方法二 int c2 = IPAddress.HostToNetworkOrder(c);//大端字节数 byte[] bb = System.BitConverter.GetBytes(c2);//字节数组 //文本(Unicode) string s = "code"; byte[] sbb = Encoding.BigEndianUnicode.GetBytes(s);//大端 byte[] sbs = Encoding.Unicode.GetBytes(s);//小端
C++判断也简单,采用Union的方式判断,因为在Union中所有的元素都放在一块内存空间中,mu.c的内存地址是和int型的变量i的起始地址对齐的,所以改变int型的值mu.i=1,如果为小端存储,则mu.c==1,反之,则为大端存储。详细可以参考:http://blog.csdn.net/anialy/article/details/8015183
void checkSystemBigOrLittle(void) { typedef union MyUnion { int i; char c; }; MyUnion mu; mu.i = 1; if(mu.c == 1) { printf("小端存储模式"); } else if (mu.c == 0) { printf("大端存储模式"); } else { printf("很抱歉,出错了"); } }
上文是各种被大牛喷的结果,后来的童鞋们请打牢基础,被喷请自查…
1 0
- 字节转换之大小端
- 字节序与大小端转换
- 大小字节顺序转换
- 大小字节顺序转换
- 字节字符和整数转换-大小端转换-结构体内存(文件)对齐规则之总结
- 字节序之大小端模式
- 字节序之大小端模式
- int64、double字节序转换(大小端)
- 关于网络数据传输大小端字节序的转换
- 什么时候要进行大小端字节序的转换?
- [c/c++ ]字节序与大小端转换
- ARM中大小端转换和按字节反转
- 数据大小端表示及64位字节序转换
- 大小端解释判断,网络字节序转换
- 字节序大小端转换、模拟htons、htonl、ntohs、ntohl
- 自己的网络字节序转换代码(大小端字节序)
- 字节序-大小端
- 字节序-大小端
- Spring注解
- 黑马程序员——util工具类
- 浅谈C++多态性
- Ofbiz 分页代码
- 最小生成树Prim and Kruskal
- 字节转换之大小端
- python字符串字串查找 find和index方法
- 内存越界和局部变量、数组初始化
- scrapy爬虫起步(4)-- 来个scrapy的简介吧
- 淘宝开源项目TbSchedule的部署和使用
- Oracle SQL性能优化常用方法
- Linux网络编程——tcp并发服务器(poll实现)
- 第五章
- 常见编译错误提示附解决方法