首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >非线程锁互斥锁

非线程锁互斥锁
EN

Stack Overflow用户
提问于 2009-05-05 23:05:42
回答 3查看 341关注 0票数 0

这是this问题的一个分支,但删除了一些限制。

我有一个需要管理文件锁定的系统。我需要能够在一个线程中锁定一个文件(共享读锁定),然后在另一个线程中解锁它。更准确地说,我不能确定它将被解锁在哪个线程中,甚至不确定创建线程是否还在。

我还需要独占写锁定去与此,但这将是所有在同一线程。

当创建线程退出时,.NET Mutex不会工作,因为它会做额外的事情

EN

回答 3

Stack Overflow用户

发布于 2009-05-05 23:09:56

也许是一个计数为1的(命名的) SemaphoreWaitOne表示锁定,Release表示解锁?

票数 1
EN

Stack Overflow用户

发布于 2009-05-06 04:15:25

你链接到的问题是跨越进程边界,但据我所知,你只是跨越了线程……考虑到这一点,我认为Jeff Richter的ReaderWriterGate类可能很适合您的问题。它允许您控制对共享资源的访问,并对对该资源的访问请求进行排队。它似乎没有任何线程亲和力,所以如果您没有跨越进程边界,那么它可能是一个适合您的解决方案。

这里有一篇关于这个类的文章的链接……Concurrent affairs,您可以下载PowerThreading Library from here

如果您的情况真的很简单(除了从一个线程锁定和从另一个线程释放),我不明白为什么您不能在.NET中使用内置的ReaderWriterLock (尽管PowerThreading库中的应该要快得多)。Monitor class没有线程亲和性,可以从任何上下文访问,因此根据您如何使用它,这可能是您最直接的解决方案。

票数 1
EN

Stack Overflow用户

发布于 2009-05-05 23:49:26

在我看来像是Turnstile的问题。您需要管理进入的读取器,第一个读取器锁定文件,最后一个读取器解锁文件。您可以使用信号量来实现这一点。您可以优先考虑编写者,方法是让旋转栅门在编写者等待时拒绝读者。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/827323

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档