C#字节数组的常用解码处理方法
在某些情况下,比如说串口通信或者读取二进制的文件,通常会得到一个byte数组形式的数据。
然而对于这个数据处理常常令人苦恼,因为通常通信情况下,并不是一个字节代表一个字符或者某个数据,而是数据夹杂在字节与字节之间。
读取文件得到的情况:
FileInfo fi = new FileInfo(@"E:\ABC.DAT"); long len = fi.Length; FileStream fs = new FileStream(@"E:\ABC.DAT", FileMode.Open); byte[] buffer = new byte[len]; fs.Read(buffer, 0, (int)len); fs.Close();
1:将一个字节转换为16进制的字符表示
String str= Convert.ToString(buffer[i], 16); //16进制 String PrintStr = (Convert.ToString(buffer[i2], 16)).PadLeft(2, '0') + " "; //转换为2个字符长度的(不足左侧补零)
2:ASCII编码存储的转换(字节数组buffer的4到17为一个ASCII字符存储的时间)
string str_stime = Encoding.ASCII.GetString(buffer, 4, 17); DateTime stime = new DateTime(Int32.Parse(str_stime.Substring(0, 4)), Int32.Parse(str_stime.Substring(4, 2)), Int32.Parse(str_stime.Substring(6, 2)), Int32.Parse(str_stime.Substring(8, 2)), Int32.Parse(str_stime.Substring(10, 2)), Int32.Parse(str_stime.Substring(12, 2)), Int32.Parse(str_stime.Substring(14, 3)));
3:如果某个数据存储在字节之间
如2个字节 0000|0000||0000|0000
字节0 字节1
这两个字节的前5个bit表示一个数据,再6个bit表示一个数据,后5个bit又表示一个数据
由于在C#中int为32位数据,可以存储4个字节的数据,int16可以表示2个字节,然后通过移位和位运算来处理。
int16 iData = buffer[1] + (buffer[0] << 8) iData1 = iDate & 0x1F; iData2 = (iDate >> 5) & 0x3F; iData2 = (iDate >> 11) & 0x1F;
如有错误,敬请指教。