至少可以通过三种方法来进行转换。
在.NET Framework类库的System名字空间中有个叫做BitConverter的类,它是专门用来进行这种转换的。
很简单的一种方法:int i=100; byte[] result = BitConverter.GetBytes(i);
它有一个GetBytes方法,对于大多数简单的类型来说,该方法都被重载了,它可以返回一个byte array来保存你传递的值。它也有几个ToTypeName方法用来将一个byte array转换成一个基本类型(primitive type):byte[] b = BitConverter.GetBytes(
<wbr> <wbr> 0xba5eba11 );<br>//{0x11,0xba,0x5e,0xba}<br>uint u = BitConverter.ToUInt32(<br> <wbr> <wbr> new byte[] {0xfe, 0x5a, 0x11,<br> <wbr> <wbr> 0xfa},0 ); // 0xfa115afe</wbr></wbr></wbr></wbr></wbr></wbr>
在运用BitConverter类时,要记住的一个重点是它的行为取决于硬件架构(代码在该硬件架构上运行)的字节顺序(endianness)——就是说,integer字节在内存中的存储顺序。如果你将bit保存为可以在许多不同平台上读取的一个文件格式,那么就会出问题。BitConverter有一个公有的IsLittleEndian字段,你可以查看它是如何运行的,但遗憾的是,你并不能改变它。
也可以不用BitConverter类,而通过手动位移(bit shifting)来进行转换: b = new byte[] {0xfe,0x5a,0x11,0xfa};
u = (uint)(b[0] | b[1] << 8 |
<wbr> <wbr> b[2] << 16 | b[3] << 24);<br>b[0] = (byte)(u);<br>b[1] = (byte)(u >> 8);<br>b[2] = (byte)(u >> 16);<br>b[3] = (byte)(u >> 24);<br><br>用这种方法就可以避免字节顺序问题,因为可以完全控制字节的位置。</wbr></wbr>
最后——如果不介意用不安全的代码——可以通过直接的内存拷贝来实现转换,把一个指向byte array的指针(pointer)转换成一个指向integer类型的指针,然后取它的值(dereference):unsafe {
<wbr> <wbr> fixed ( byte* pb = b )<br> <wbr> <wbr> u = *((uint*)pb);<br>}</wbr></wbr></wbr></wbr>
同BitConverter一样,这个方法的运行结果取决于代码在何种硬件上运行。
如果要进行很多这种转换——比如说在一个循环中——而且想得到最佳性能,那么建议用最后两种方法中的一种。BitConverter有些慢,尽管区别不大