相关疑难解决方法(0)

File.AppendAllText是否管理冲突(即多用户并发)?

File.AppendAllText管理来自多个作家的冲突?

研究

我注意到MSDN文档并没有提供任何一种位置,所以我决定我会反映代码,看看它的作用.以下是从以下方法调用的方法File.AppendAllText:

private static void InternalAppendAllText(string path, string contents, Encoding encoding)
{
    using (StreamWriter streamWriter = new StreamWriter(path, true, encoding))
    {
        streamWriter.Write(contents);
    }
}
Run Code Online (Sandbox Code Playgroud)

而你可以看到它只是利用了一个StreamWriter.所以,如果我们深入研究它,特别是它使用的构造函数,我们发现它最终会调用这个构造函数:

internal StreamWriter(string path, bool append, Encoding encoding, int bufferSize, bool checkHost) : base(null)
{
    if (path == null)
    {
        throw new ArgumentNullException("path");
    }
    if (encoding == null)
    {
        throw new ArgumentNullException("encoding");
    }
    if (path.Length == 0)
    {
        throw new ArgumentException(Environment.GetResourceString("Argument_EmptyPath"));
    }
    if (bufferSize <= 0) …
Run Code Online (Sandbox Code Playgroud)

.net c# io

14
推荐指数
2
解决办法
3677
查看次数

Mutex的"安全"处理?

我经常从另一个进程正在写入的内存映射文件中读取并使用互斥锁来同步此操作.到目前为止,在我的几个测试中,这个工作正常,但是...如果我的应用程序在获取互斥锁之后和释放之前崩溃了怎么办?有没有办法保证互斥锁的发布,即使发生了这样的崩溃?

另外,我如何处理其他进程的崩溃,这可能还没有释放互斥锁呢?每次调用mutex.WaitOne()时,是否需要处理AbandonedMutexException?

现在我正在这样做:

public MyState GetState()
{
    MyState state = new State();
    this._mutex.WaitOne();
    try
    {
        state.X = this._mmView.ReadSingle(0);
        state.Y = this._mmView.ReadSingle(4);
        [..]
    }
    finally
    {
        this._mutex.ReleaseMutex();
    }
    return state;
}
Run Code Online (Sandbox Code Playgroud)

_mmView是我之前实例化的MemoryMappedViewAccessor.整个方法GetState()作为游戏循环的一部分被调用每个帧,因此大约每隔几毫秒.

PS:此外,还有其他明显的问题,为什么这可能会失败,我还没有提到?

c# mutex memory-mapped-files

8
推荐指数
1
解决办法
2203
查看次数

标签 统计

c# ×2

.net ×1

io ×1

memory-mapped-files ×1

mutex ×1