坑爹的UTF-8-BOM编码

前言

今天从一个txt文本读取第一行,只有一个数字0。
可是读取后int.Parse()的时候报错:Input string not valid
断点跟踪了一下,读出来的是个数字。也没有空格什么的。
再打印一下Length,发现Length是2。
fuck。
既然是Length是2我给你ToArray()看看具体的字符。
fuck again。ToArray()报错:Input string not valid
于是想起来可能是BOM头的原因。
Notepad看看,果不其然:
坑爹的UTF-8-BOM编码_第1张图片

解决方法

再看看生成这个txt文本的代码:
File.WriteAllText(path, content.TrimEnd(), Encoding.UTF8);

改成:
File.WriteAllText(path, content.TrimEnd(), new UTF8Encoding(false));
生成的文本就是no-BOM的了。

补充

另外经过测试,通过以下流的方式生成的txt是no-BOM的:

//将string转为byte数组
byte[] array = Encoding.UTF8.GetBytes(content.TrimEnd());
//创建一个文件流
FileStream fs = new FileStream(path, FileMode.Create);
//将byte数组写入文件中
fs.Write(array, 0, array.Length);
fs.Close();

你可能感兴趣的:(C#)