FileStream locking a file for reading and writing

坚强是说给别人听的谎言 提交于 2019-12-01 03:00:13

问题


I have the following code block which is giving me a headache.

Logically it should work as I am using the filestream providing the lock within the using statement. When it gets to the line that creates the StreamWriter, it fails saying "the file is not writable".

Now my program is a multithreaded application. Any thread could be trying to write to this file. I need the program to lock the file, read the contents, check the contents, then write back any changes. During that process, no other thread should be able to access that file.

using (var fs = File.Open(fileLoc, FileMode.Open, FileAccess.ReadWrite, FileShare.None))
{
    var sr = new StreamReader(fs);
    var str = sr.ReadToEnd();
    var strArray = str.Split(',');
    if (strArray.Any(st => st == text))
    {
        return;
    }
    sr.Close();

    var sw = new StreamWriter(fs);
    sw.Write(str + text);
    sw.Flush();
    sw.Close();
}

回答1:


The FileShare.None flag does not cause threads to queue, it just locks the file, hence the exception that you get. To provide mutually exclusive access you can lock a shared object prior to writing.

But you say this "Now my program is a multithreaded application. Any thread could be trying to write to this file." Now, do these threads all use exactly the same method to write to the file? Let's assume they do, then this should work ...

Create a static class variable ...

private static object lockObject = new object();

Use it here ...

lock (lockObject) 
{
    using(var sw = new StreamWriter(fs))
    {
       sw.Write(str + text);
    }
}

I have made some assumptions about the threads, so you may have to look up info on synchronization if this doesn't work or provide some more info to us.

Also, please close your StreamReader earlier (in case the method returns earlier). Close it immediately after you use it or better yet use using.




回答2:


Try Thread Synchronization. You can find more details from this link.




回答3:


As in the MSDN reference the Close method

Closes the StreamReader object and the underlying stream, and releases any system resources associated with the reader.

Thus it seems that the subsequent call to StreamWriter fails to use a closed resource, giving you the message "the file is not writable".

Try this

            using (var fs = File.Open(path, FileMode.Open, FileAccess.ReadWrite, FileShare.None))
        {
            using (var sr = new StreamReader(fs))
            {
                var str = sr.ReadToEnd();
                // ...

                using (var sw = new StreamWriter(fs))
                {
                    // ...
                }
            }
        }


来源:https://stackoverflow.com/questions/13698380/filestream-locking-a-file-for-reading-and-writing

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!