草庐IT

future-proof

全部标签

c++ - std::future 或 std::shared_future 等待多线程

我有一个线程从容器中获取每个元素并向数据库发送上传请求。上传是同步完成的。容器中的元素是金融合约,它们可能有也可能没有与之关联的数据结构调用ticktable。现在,对于那些有ticktable的合约,我必须进行两次上传。1)首先将ticktable上传到db。db返回一个id。2)将id附加到契约(Contract)上,然后上传契约(Contract)。因此,例如,如果我循环遍历包含100个合约的容器,假设其中30个具有ticktable,其余70个没有。我想弄清楚std::future或std::shared_future是否适合这样的任务?我尝试通过将future与30个合约中的

c++ - 在没有阻塞的情况下开始剩余的 future

我在一个集合上有一个循环,我必须在其中执行昂贵的计算。我想使用future的类(class)并行执行此操作。据我了解,async要么启动线程,要么延迟它,仅在我调用get()或wait()时才启动它。因此,当我有线程未启动并尝试获取结果时,我会阻塞主线程并进行顺序处理。有没有办法启动剩余的延迟进程,所以一切都是并行计算的,并且在我调用get()时不会阻塞。//dothecalculationsstd::vector>futureList;for(autoelem:container){futureList.push_back(std::async(fct,elem));}//start

c++ - 计算可以从墙上反弹的球的 future 位置

我正在尝试做一些future的预测,我想计算球应该在哪里达到特定的高度(y)。球向上发射,可以从游戏的两侧弹起。弹跳不影响移动速度。我当前的配置是左下角是(0,0),右下角是(10,0),没有上限。代码:voidgetPositionXAtHeight(floatheight,Vec2pos,Vec2vel,floatgravityForce=9.8f,floatgameWidth,float&positionX){floata=gravityForce/2.0f;floatb=vel.y;floatc=pos.y-height;floatt=(sqrtf((b*b)-(4.0f*a*

c++ - 获取 std::future<T>::wait_for 的运行时间

有没有一种简单的方法来获取std::future::wait_for期间耗时?如果没有超时发生?我想实现这样的目标:std::futurefutureRet=std::async(std::launch::async,&Someone::doSomething,this);futureRet.wait_for(std::chrono::seconds(30));coutseconds.";是否有一种“getElapsedTime()”函数,还是我必须自己计算耗时? 最佳答案 有一个简单的方法使用:autostart=std::chr

c++ - 为什么执行者不在 Concurrency TS 和 std::future 接口(interface)中了?

std::future::then的接口(interface)在论文中N3784包含一个重载版本,该版本接受一个执行程序(在N3562中有更多描述)作为参数。所以如果你想更多地控制回调在哪个线程上执行,你可以这样做。但是这里的官方文档介绍了并发TS中的所有功能http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2015/p0159r0.html#futures.unique_future不包括.then()的重载并且根本不提及执行程序。它说Whentheobject'ssharedstateisready,thecontinuation

c++ - 多次调用 `std::future::then` 的行为是什么?

根据ConcurrencyTS,下面的代码会发生什么?autof0=std::async([]{return0;});autof1=f0.then([](auto&f){returnf.get()+10;});autof2=f0.then([](auto&f){if(!f.valid())return;returnf.get()+10;});到第三行代码执行时,f0已经有了continuation,所以根据TS,f0应该抛出异常,中止程序,UB或者有不同的行为?我不清楚。 最佳答案 根据cppreference,它是未定义的:Att

c++ - 在设置值之前是否必须调用 promise.get_future() ?

来自http://www.cplusplus.com/reference/future/promise/get_future/:Afterthisfunctionhasbeencalled,thepromiseisexpectedtomakeitssharedstatereadyatsomepoint[...]我不确定这是否意味着此操作顺序是强制性的:get_future()设置值()是否也有可能只有在设定值后才能从promise中获得future? 最佳答案 据我所知没有这样的限制。std::promise::set_value导

c++ - 标准保证在移动 std::packaged_task 后安全使用 std::future 吗?

假设我们有以下代码:#include#includeintmain(){autopackagedTask=std::packaged_task([]{std::cout(std::move(packagedTask));autov1=packagedTaskFuture.valid();//isvalidautov2=packagedTaskFuture.wait_for(std::chrono::seconds(0));//timeoutstate(*packagedTaskPtr)();//executetaskautov3=packagedTaskFuture.wait_for(

聚焦科技女性 - “Her Future, Her Way”

微软Reactor为帮助广开发者,技术爱好者,更好的学习.NETCore,C#,Python,数据科学,机器学习,AI,区块链,IoT等技术,将每周三到周六,组织3~5场线上分享活动。欢迎跟着我们一起来学习。 活动介绍如今,在互联网各个技术领域中,越来越多地涌现出一些女性从业者的身影。无论是学生群体、开发者或是科技创业者;无论是传统技术门类,或是前沿技术领域,都有着相当一部分女性从业者活跃的身影。她们从不受锢于条条框框,有着良好的专业素养,出色的专业技能,和不安现状勇于挑战的创业精神。  又是一年3月8日国际妇女节,微软最有价值专家项目组,微软加速器,微软学生大使项目组,微软 Reactor 

c++ - 未使用的私有(private)虚拟方法是否允许在不破坏 ABI 兼容性的情况下进行 future 扩展?

我正在开发一个共享库。假设我有以下类定义:classMyClass{public://publicinterfaceprivate:virtualvoidfoo1(int);virtualvoidfoo2(int,bool);virtualvoidfoo3(double);virtualvoidreserved1();virtualvoidreserved2();virtualvoidreserved3();classImpl;Impl*impl_;};reserved#虚拟方法不会在客户端代码中被覆盖,也不会从任何地方调用。它们充当future扩展的占位符。假设我将其中一个保留方法替