草庐IT

future_status

全部标签

c++ - 如何终止 std::future?

我对C++11std::future的一些事情感到困惑。我想动态平衡工作负载,所以如果有一些处理器空闲,我创建一个std::future和std::async来划分剩余的数据。它工作正常。std::futuref[MAX_CHILD];for(eachdataitem){if(found_idle_processor)f[i]=std::async(...);process();}//Atlast,querytheresultoff.for(eachfuture)hold=f[i].get();但有时,一旦找到一些特殊数据项,所有其他数据将被丢弃,程序应立即给出最终结果,然后启动另一个

c++ - 在同一个线程的同一个实例上多次调用 shared_future::get() 是否合法?

我找不到关于此事的直接确认或反驳。所有答案似乎都解决了“从多线程访问”方面的问题,而不是重复访问本身。标准是否定义了std::shared_future的行为?boost::shared_future怎么样? 最佳答案 根据std::shared_future::valid中的cppreferenceUnlikestd::future,std::shared_future'ssharedstateisnotinvalidatedwhenget()iscalled.这是有道理的。如果不是这种情况,那么您将无法让多个线程调用get。.我

c++ - 为什么我们需要 std::promise 和 std::future?

我想知道为什么我们同时需要std::promise和std::future?为什么C++11标准将get和set_value分成两个单独的类std::future和std::promise?在这个post的答案中,它提到:Thereasonitisseparatedintothesetwoseparate"interfaces"istohidethe"write/set"functionalityfromthe"consumer/reader".我不明白躲在这里有什么好处。但是如果我们只有一个类“future”不是更简单吗?例如:promise.set_value可以替换为future

c++ - 使用 std::packaged_task 时 std::future 仍然延迟(VS11)

看来除非你调用std::async一个std::future绝不会设置为除future_status::deferred以外的任何其他状态除非你调用get或wait关于future。wait_for&wait_until将继续不阻塞并返回future_status::deferred即使任务已经运行并存储了结果。这是一个例子:#includevoidmain(){autofunc=[](){return5;};autoasyncFuture=std::async(std::launch::async,func);autostatus=asyncFuture.wait_for(std::

c++ - 为什么 C++ 异步在没有 future 的情况下按顺序运行?

#include#includevoidmain(){std::async(std::launch::async,[]{std::cout在这段代码中,只会输出“async...”,也就是说这段代码是阻塞在async的。但是,如果我添加future并让语句变为:std::futurefut=std::async([]{std::cout然后一切顺利(不会阻塞)。我不确定为什么会这样。我认为异步应该在单独的线程中运行。 最佳答案 来自encppreference.com:Ifthestd::futureobtainedfromstd:

C++20 协程 : implementing an awaitable future

自从协程TS在Kona的ISOsession上被接受到C++20中后,我开始自己尝试一下它们。Clang已经对协同程序提供了不错的支持,但仍然缺乏库支持的实现。特别是Awaitable类型,例如std::future、std::generator等还没有实现。因此,我决定让std::future成为可等待的。我主要关注talkbyJamesMcNellisatCppCon2016,特别是这张幻灯片:现在是2019年,我实际上在处理这张幻灯片上的代码(大概未经测试?)时遇到了一些问题:在我看来,重载operatorco_await已经不是问题了?相反,应该使用promise_type的可

c# - 面向 future 的大型 UI 应用程序 - 具有 2008 功能包的 MFC 或 C# 和 Winforms?

我的公司使用VisualC++中的MFC作为UI开发的事实标准开发了一个长期存在的产品。我们的代码库包含大量必须保持运行的遗留/陈旧代码。其中一些代码比我还早(最初是在70年代后期编写的),我们团队的一些成员仍在使用VisualStudio6。不过,值得庆幸的是,内部得出的结论是,与竞争对手的产品相比,我们的产品看起来有些过时,需要采取一些措施。我目前正在开发UI的一个新区域,该区域与产品的其余部分完全不同。因此,我有机会尝试"new"技术堆栈,作为一种试验场,然后再开始漫长的UI其余部分迁移过程。我在业余时间使用C#与WindowsForms和.netFramework有一段时间并且

c++ - std::list<std::future> 析构函数不阻塞

我有一个多线程应用程序,有一个循环等待用户输入作为主线程。在正确的输入上,它应该停止循环并等待所有其他线程正确结束。为此,我创建了一个std::list,其中放置了为创建线程而创建的std::future对象std::list>threads;threads.emplace_front(std::async(std::launch::async,...));我的印象是,让list超出范围应该阻塞,直到所有线程返回它们的main函数,因为list的析构函数将destrurct所有std::future元素和thedestructorofthose将等待线程完成。编辑:因为它是相关的,所以

c++ - 异常传播和 std::future

我的理解是,当一个异步操作抛出异常时,它会传播回一个调用std::future::get()的线程。然而,当这样的线程调用std::future::wait()时,异常不会立即传播-它会在随后调用std::future::得到()。但是,在这种情况下,如果在调用std::future::wait()之后future对象超出范围,但在之前调用std::future::get()?对于那些感兴趣的人,这里有一个简单的例子。在这种情况下,异常由thread/future包静默处理:#include"stdafx.h"#include#include#includeint32_tDoWork(

c - Windows 虚拟 HID 框架 VhfCreate 方法返回 STATUS_INVALID_DEVICE_REQUEST

我正致力于在Windows10中创建虚拟HID设备。我正在尝试使用Windows虚拟HID框架(如此处所述:https://msdn.microsoft.com/en-us/library/windows/hardware/dn925056(v=vs.85).aspx)构建驱动程序。在我目前的阶段,我只是在努力让驱动程序正确安装在Windows10虚拟机上。我的驱动代码如下:#include#include#includeDRIVER_INITIALIZEDriverEntry;EVT_WDF_DRIVER_DEVICE_ADDBBKbdEvtDeviceAdd;typedefstru