FileInfo.Length大于0但文件是否为空?

时间:2010-10-14 17:36:11

标签: c# file-io

我有一个应用程序可以处理一堆文本文件。目前,我有这样的代码(剪下摘录):

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。

4 个答案:

答案 0 :(得分:5)

除了字节顺序标记外,您可能有一个空文件。我认为 TextReader.ReadToEnd()会删除字节顺序标记,为您提供一个空字符串。

或者,文件可能在检查长度和读取之间被截断。

出于诊断目的,我建议您在获得空字符串时记录文件长度。

答案 1 :(得分:2)

看到你有catch (IOException)阻止?即使文件不为空,这也会返回一个空字符串并触发断言。

答案 2 :(得分:0)

如果我记得很清楚,文件以文件结尾结束,当你调用ReadToEnd时不会包含该文件。

因此,文件大小不是0,但它的内容大小是。

答案 3 :(得分:0)

getFileContents方法有什么用?

在调用ReadToEnd()之前,它可能正在将流的指针重新定位到流的末尾。