你的位置:首页 > 软件开发 > ASP.net > 判断.net中在windows系统下的字节序

判断.net中在windows系统下的字节序

发布时间:2016-04-07 19:00:10
字节序,是指字节在内存中的存储顺序。其又分为大端字节(Big-Endian)序和小端字节序(Little-Endian)。  以下摘自百度百科:  a) Little-Endian就是低位字节排放在内存的低地址端,高位字节排放在内存的高地址端。  b) Big-Endian就是高 ...

  字节序,是指字节在内存中的存储顺序。其又分为大端字节(Big-Endian)序和小端字节序(Little-Endian)。

  以下摘自百度百科:

  a) Little-Endian就是低位字节排放在内存的低地址端,高位字节排放在内存的高地址端。

  b) Big-Endian就是高位字节排放在内存的低地址端,低位字节排放在内存的高地址端。

  什么意思呢?

  我们有一个int32的值:16909060,它的二进制表示方式是:0000 0001,0000 0010,0000 0011,0000 0100 (为了方便观看,我加了','号)

  那么,在内存中我们需要4个字节来保存这个整型数值。假设需要的内存地址为:0x00000001,0x00000002,0x00000003,0x00000004

  对于小端字节序,它的存放顺序为:

 

0x000000010x000000020x000000030x00000004
0000 01000000 00110000 00100000 0001

  对于大端字节序,它的存放顺序为:

0x000000010x000000020x000000030x00000004
0000 00010000 00100000 00110000 1000

  那么,在.net中是采用哪种字节序呢?

  先下结论:.net在内存中采用的是Little-Endian。 

  测试原理:利用 Buffer.BlockCopy 方法将一个int32位的值复制到int16值中。 Buffer.BlockCopy  方法将指定的count个数组从src复制到dst,并能指定开始复制的偏移位置。BlockCopy 方法使用内存的偏移量访问 src 参数数组中的字节,而不是使用索引或数组上下限等编程构造。注意,是内存的偏移量,即该方法是从内存中一个一个字节的复制值,而不是直接复制数值结构

  以下是源代码:

 1      var sours = new int[] { 175 }; 2       var dest = new short[1]; 3       var sp = 0; //源序列偏移地址 4       var dp = 0; //目标位置偏移地址 5       var count = 2; //一次拷贝字节数 6  7       Buffer.BlockCopy(sours, sp, dest, dp, count); 8       foreach (var i in dest) 9       {10         Console.WriteLine(i);11       }  

原标题:判断.net中在windows系统下的字节序

关键词:.NET

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。