C# WP8互斥-资源锁定

C# WP8互斥-资源锁定,c#,windows-phone-8,windows-phone,C#,Windows Phone 8,Windows Phone,我在理解互斥类以及如何在WP8应用程序中正确使用它时遇到了问题。我试图做的是一次只允许ScheduledAgent或应用程序向存储器读/写文件。我尝试过各种各样的方法,但都不走运。任何帮助都将不胜感激 日程安排代码: 下面是调用ReleaseMutex()时出错的代码。当我像这样创建互斥对象时,这个问题得到了解决:新建互斥对象(true,“FlightPathData”)。但是我永远也找不到锁,只能挂在WaitOne()上 错误 从未同步的代码块调用了对象同步方法 代码 不能将线程仿射锁与asy

我在理解互斥类以及如何在WP8应用程序中正确使用它时遇到了问题。我试图做的是一次只允许ScheduledAgent或应用程序向存储器读/写文件。我尝试过各种各样的方法,但都不走运。任何帮助都将不胜感激

日程安排代码:

下面是调用ReleaseMutex()时出错的代码。当我像这样创建互斥对象时,这个问题得到了解决:新建互斥对象(true,“FlightPathData”)。但是我永远也找不到锁,只能挂在WaitOne()上

错误

从未同步的代码块调用了对象同步方法

代码


不能将线程仿射锁与
async
code一起使用。这是因为
wait
会导致方法返回(同时保持互斥),然后另一个线程可以继续
async
方法并尝试释放它不拥有的互斥。如果这令人困惑,我有一个建议,你可能会觉得有用


因此,您不能使用
互斥锁
或其他线程仿射锁,如
。但是,您可以使用。在
async
方法中,您将使用
Wait WaitAsync
而不是
Wait

这一行:savedMetars=Wait Data.LoadMetarsAsync(facility.Identifier);导致任务进入另一个线程,因为它是异步的,并且当它尝试释放互斥时,它不能。我对代码进行了注释,所有内容都正常工作……非常奇怪。@Stehen:请您详细说明一下“不能将互斥与异步代码一起使用”这一点好吗?在我的UWP应用程序中,我需要在前台应用程序和后台任务(在单独的进程中)之间同步资源访问(例如存储文件)。在我的互斥体中似乎工作得很好(我知道这并不是证明)。实际上,我刚刚读完一篇关于async/await的文章,正要发布您刚才所说的内容。我不知道SemaphoreSlim,我肯定会读一些这方面的文章。话虽如此,我最终还是创建了其他方法,这些方法可以同步写入IsolatedStorage,并且确实解决了这个问题。感谢您的帖子和链接@Stehen:你能详细说明一下“你不能用异步代码使用互斥锁”吗?在我的UWP应用程序中,我需要在前台应用程序和后台任务(在单独的进程中)之间同步资源访问(例如存储文件)。在我的测试中,互斥体似乎工作得很好(我知道这不是证明)。@peterminl:mutex是线程仿射的,所以它们不能与异步代码一起工作。
readonly Mutex mutex = new Mutex(false, "FlightPathData");

protected async override void OnInvoke(ScheduledTask task)
{
      List<METAR> savedMetars = null;
      var facility = ....;

      bool mutexAcquired = mutex.WaitOne();
      try
      {
           if (mutexAcquired)
           {
               savedMetars = await Data.LoadMetarsAsync(facility.Identifier);
               //Thread.Sleep(15000);
           }
       }
       finally
       {
           if (mutexAcquired)
           {
               mutex.ReleaseMutex();
           }
       }

       NotifyComplete();
 }
static readonly Mutex mutex = new Mutex(true, "FlightPathData");
...
mutex.WaitOne();
var savedMetars = await Data.LoadMetarsAsync(this.Facility.Identifier);
mutex.ReleaseMutex();