- 问题描述
在C#中使用Encoding将字节数组变成字符的时候,会将特殊字符(控制字符)全部变成问号。会出现一个现象,
将文件读取到字节后,用Encoding变成字符后,在变成字节流。此时的字节流和刚开始的字节流是不同的。代码如下
byte[] bytes=new byte[]{137, 80, 78, 71, 13, 10, 26, 10, 0, 0};
string t1 = Encoding.UTF8.GetString(bytes);
- 解决方法一
public static String ByteToString(byte[] bytes)
{
string s = "";
for(int i=0;i <bytes.Lenght;i++)
{
s = s + Convert.ToChar(bytes[i]).ToString();
}
return s;
}
这种采用字符拼接效率很低,最好采用下面的实现。
- 解决方法二
public static String ByteToString(byte[] bytes)
{
StringBuilder strBuilder = new StringBuilder();
for (int i = 0; i <bytes.Length ; i++) {
strBuilder.Append(Convert.ToChar(bytes[i]));
}
return strBuilder.ToString();
}