有效地暂停异步操作,等待用户输入
异步编程通常需要暂停长期运行的任务,直到用户互动为止,例如单击按钮。 本文探讨了暂停类似GetResults
的异步方法时忙碌待招待的有效替代方案,直到特定事件触发。
>避免效率低下的轮询
>连续检查该事件(忙碌的播放)的传统方法效率很低。 事件驱动的解决方案提供了一种更优雅和表现的方法。
>利用信号量
>SemaphoreSlim
类提供了坚固的基于信号量的解决方案。 初始化一个信号量为0,最大计数为1。“继续”按钮的事件处理程序使用Release()
释放信号量。 在GetResults
>中,await signal.WaitAsync()
阻止执行直到释放信号量为止。
<code class="language-csharp">private SemaphoreSlim signal = new SemaphoreSlim(0, 1); private void ButtonContinue_Click(object sender, RoutedEventArgs e) { signal.Release(); } private async Task GetResults() { await signal.WaitAsync(); // Continue processing }</code>
>利用事件信号的taskCompletionsource
>另外,创建一个代表按钮单击结果的任务。 事件处理程序使用TaskCompletionSource<bool>
完成此任务。 SetResult()
等待此任务,暂停执行直到完成。GetResults
>
<code class="language-csharp">private TaskCompletionSource<bool> tcs = new TaskCompletionSource<bool>(); private void ButtonContinue_Click(object sender, RoutedEventArgs e) { tcs.SetResult(true); } private async Task GetResults() { await tcs.Task; // Continue processing }</code>
以上是如何暂停异步方法,直到发生事件?的详细内容。更多信息请关注PHP中文网其他相关文章!