我正在尝试用C++/WinRT编写一个基于协程的后台线程,它在取消令牌的状态上循环,因为我需要在取消时执行一些清理操作。
我正在尝试遵循MSDN (https://docs.microsoft.com/en-us/windows/uwp/cpp-and-winrt-apis/concurrency#canceling-an-asychronous-operation-and-cancellation-callbacks)上的文档,但是示例代码的改编版不能编译,并且cancellation_token_t类型似乎不可调用。
void BackgroundThreadManager::Start()
{
this->m_Thread = this->RunAsync();
}
void BackgroundThreadManager::Stop()
{
if (this->m_Thread)
{
m_Thread.Cancel();
m_Thread = nullptr;
}
}
IAsyncAction BackgroundThreadManager::RunAsync()
{
winrt::resume_background();
auto token{ winrt::get_cancellation_token() };
while (!token())
{
co_await this->DoSomethingAsync();
}
co_await this->DoSomeCleanupAsync();
}不幸的是,这无法编译,并在引用"while (!C2064())“行时显示"error token: term‘t evaluate to a function参数为0”。
代码同意这一点,因为get_cancellation_token_t的定义(在base.h中)是
struct get_cancellation_token_t {};我猜我从根本上做错了什么,或者MSDN文档已经过时了。有什么线索吗?谢谢!
发布于 2019-01-15 01:48:11
您忘记了在get_cancellation_token()表达式上使用co_await。co_await提供了库需要到达的钩子,并获取可能被取消的IAsyncAction实例。顺便说一句,您还忘记了co_await resume_background()表达式。
此外,请注意,协程也会在挂起点(co_await)自动取消,因此使用取消回调可能会更好,以确保您的取消逻辑不会被忽略。
https://stackoverflow.com/questions/54169072
复制相似问题