我有一个应用程序可以处理一堆文本文件。目前,我有这样的代码(剪下摘录):
FileInfo info = new FileInfo(...)
if (info.Length > 0) {
string content = getFileContents(...);
// uses a StreamReader
// returns reader.ReadToEnd();
Debug.Assert(!string.IsNullOrEmpty(contents)); // FAIL
}
private string getFileContents(string filename)
{
TextReader reader = null;
string text = "";
try
{
reader = new StreamReader(filename);
text = reader.ReadToEnd();
}
catch (IOException e)
{
// File is concurrently accessed. Come back later.
text = "";
}
finally
{
if (reader != null)
{
reader.Close();
}
}
return text;
}
为什么我收到失败的断言? FileInfo.Length属性已用于验证文件是否为空。
编辑:这似乎是一个错误 - 我正在捕获IO异常并返回空字符串。但是,由于围绕fileInfo.Length()的讨论,这里有一些有趣的东西:fileInfo.Length为一个空的,只有BOM标记的文本文件(在记事本中创建)返回2。
答案 0 :(得分:5)
除了字节顺序标记外,您可能有一个空文件。我认为 TextReader.ReadToEnd()
会删除字节顺序标记,为您提供一个空字符串。
或者,文件可能在检查长度和读取之间被截断。
出于诊断目的,我建议您在获得空字符串时记录文件长度。
答案 1 :(得分:2)
看到你有catch (IOException)
阻止?即使文件不为空,这也会返回一个空字符串并触发断言。
答案 2 :(得分:0)
如果我记得很清楚,文件以文件结尾结束,当你调用ReadToEnd时不会包含该文件。
因此,文件大小不是0,但它的内容大小是。
答案 3 :(得分:0)
getFileContents
方法有什么用?
在调用ReadToEnd()之前,它可能正在将流的指针重新定位到流的末尾。