计算机硬件有两种储存数据的方式: 大端字节序(big endian)和小端字节序(little endian)。

比如十六进制数0x0102,十六进制每个数字占4bit,四个数字16bit,也就是2byte,2个字节存储。0x0102高位字节是0x01,低位字节是0x02。

l 大端字节序 :高位字节在前,低位字节在后,这是人类读写数值的方法。

内存地址

0x100

0x101

大端字节序

01

02


l 小端字节序 :低位字节在前,高位字节在后。

内存地址

0x100

0x101

小端字节序

02

01


因此,在大端字节序和小端字节序不同的计算机设备上,Buffer.BlockCopy()拷贝的数据是不同的,在大端字节序设备上,拷贝的数据是0x0102;在小端字节序设备上,拷贝的数据是0x0201,所以Array.Copy()接口存在的意义就在这里了。

请看下面的例子,当只拷贝一个字节的长度,复制给arr1数组时,因为Windows是基于小端字节序的,所以只拷贝了0x02到了arr[0]的第一个偏移位置。

下面的四个格子,代表int的四个字节

arr[0]

02

01

0

0

Arr1[0]

0

02

0

0

arr1[0]的值就是0x0200,转化为十进制就是512

static void Main(string[] args)
            int[] arr = new int[10];
            int[] _arr1 = new int[10];
            arr[0] = 0x0102;//十进制 258
            //最后一个count是字节在内存中的偏移量
            Buffer.BlockCopy(arr, 0, _arr1, 1, 1);
            Console.WriteLine(arr[0]);//十进制 258
            Console.WriteLine(_arr1[0]);//十进制 512

因此,如果错误的传入数组的数据长度,会导致数据并没有拷贝完整。

计算机硬件有两种储存数据的方式:大端字节序(big endian)和小端字节序(little endian)。比如十六进制数0x0102,十六进制每个数字占4bit,四个数字16bit,也就是2byte,2个字节存储。0x0102高位字节是0x01,低位字节是0x02。l大端字节序:高位字节在前,低位字节在后,这是人类读写数值的方法。 ...
现代CPU的累加器一次至少能加载4个字节,即一个整数。这4个字节再内存中的排序将影响它被累加器装载成的整数的值。这就是字节序问题。字节序分为大端序与小端序,即big endian、little endian。 大端序是指一个整数的高位字节存储在内存地址的低地址处,低位字节存储在内存高地址处。小端序正好相反。下面看0x0102在两种内存结构中的存储方式。 0x0102占两个字节:高位字节 01:0000 0001,低位字节02:0000 0010 内存地址位: 低 ----------------&g
所以区分大小端的重点在于起始地址内存的是高序字节还是低序字节。 那么什么是高序字节呢 高序字节就是值的高位 比如 十进制数字123456 那么1就是这个值的高位, 6是这个值的低位。 弄清楚这个我们再看大小端就很容易了 我们想把0x0102这个十六进制的数存到计算机中去(0x0102转换成二进制是0000 0001 0000 0002) 计算机有两种存储方式见下图(前提: short型的大小是2字节)
何为大端序,小端序? 简单点说,就是字节的存储顺序,如果数据都是单字节的,那怎么存储无所谓了,但是对于多字节数据,比如int,double等,就要考虑存储的顺序了。注意字节序是硬件层面的东西,对于软件来说通常是透明的。再说白一点,字节序通常只和你使用的处理器架构有关,而和编程语言无关,比如常见的Intel x86系列就是小端序。 Big-endian(大端序) 数据的高位字节存放在地址的低端...