本博文紧跟着上一篇博文的例子。
Launch策略
你也可以强迫asyn()绝不拖延目标函数的执行,只要明确出入一个launch策略用来指挥async(),告诉它当它被调用的时候应该明确地以异步方式启动目标函数。
std::future<long> result=std::async(std::launch::async,func1);
如果异步调用在这里无法实现,程序会抛出一个std::system_error 异常 并带有错误码:resource_unavailable_try_again.
有了这个launch()策略,就不用调用get()了。如果你不调用get(),当离开future object作用域的时候(此处是指main()结束),程序会等待后台任务(background task)的结束,尽管如此,调用get()会让行为更加清晰。
也可以强制延缓执行(deferred execution),以std::launch:deferred为发射策略传给async()。
处理异常(暂时略过)
等待和轮询(Waiting and Polling)
一个future<>只能被调用get()一次。在那之后,future 就处于无效的状态,而这种状态只能借由对future调用valid()来检测。 此情况下对它的任何调用(析构除外)会导致不可预期的行为。
但是future也提供了一个接口,允许我们等待后台操作的完成而不需要处理其结果。这个接口就是wait(),它可以被调用一次以上,也可以结合一个一段时间,或者时间点来限制等待时间。
只要对某个future()调用wait(),就可以强制启动该future象征的线程并等待这一后台操作的终止。
std::future<> f(std::async(func

最低0.47元/天 解锁文章
9369

被折叠的 条评论
为什么被折叠?



