我知道答案一定在某个地方,我应用了许多其他问题和 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
方法使代码工作正常。我仍然想知道问题是什么,无论如何问题看起来已经解决了。