1

我知道答案一定在某个地方,我应用了许多其他问题和 MSDN 本身的建议,但我可能在这里忽略了一些东西。

这是我的方法,我用它将输出转储到文件。为清楚起见,附加了锁定对象声明。

private static Object fileLock = new Object();
private static void WriteToFile(string msg, bool WriteLine)
{
    lock (fileLock)
    {
        msg = DateTime.Now.ToShortTimeString() + " - " + msg;

        FileInfo F = new FileInfo("dump.txt");
        using (StreamWriter writer = F.Exists ? F.AppendText() : F.CreateText()) //<--THIS LINE THROWS
        {
            if (WriteLine)
                writer.WriteLine(msg);
            else
                writer.Write(msg);
        }
    }
}

问题是:为什么上面的行会在我第二次调用该方法时using引发抱怨另一个进程正在使用该文件?IOException

我在我的代码周围这样称呼它:

Console.WriteLine(something)
#if(DEBUG)
    Extensions.WriteToFile(something,true);
#endif

同样,我确信这是一个微不足道的问题,其他人问过这样的问题得到了正确的答案,但我无法挖掘它。

更新

重构FileInfo对象并切换到File.XXX方法使代码工作正常。我仍然想知道问题是什么,无论如何问题看起来已经解决了。

4

1 回答 1

2

@Guffa:声明必须是私有静态对象 fileLock = new object();

@alex:您的代码在我的机器上运行良好,尽管对于 imo 任务来说有点太复杂了。

static void Write(string text, string file)
    {
        using (StreamWriter sw = File.AppendText(file))// Creates or opens and appends
        {
            sw.WriteLine(text);
        }
    }

也许某些防病毒软件或索引器会锁定您的转储文件。

于 2011-11-24T15:42:39.120 回答