草庐IT

future_base

全部标签

c++ - Python 到 C++ : From Deriv, 到 Base,再到 Deriv

我正在使用Boost.Python将我的C++代码公开给Python。我遇到了与将对象从一种语言多次传递到另一种语言有关的困难。这是我想要做的:C++代码classBase{public:voidbaseTest(){std::cout("Base").def("baseTest",&Base::baseTest);class_>("Deriv").def("derivTest",&Deriv::derivTest);def("call",call);}Python代码fromeventimport*defcallback(deriv):deriv.baseTest()#worksfi

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

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

python - c++中python "type(<name>, <bases>, <dict>)"的等价物是什么?

好吧,我正在将python3.3嵌入到C++应用程序中。我希望在C++端动态创建一个Python类,就像我在Python中执行以下操作一样:my_type=type("MyType",(object,),dict())我知道我总是可以导入“builtins”模块,但我一般会尽量避免在C++端导入。谢谢! 最佳答案 以下似乎工作得很好:PyObject*type(constchar*name,boost::python::tuplebases,boost::python::dictdict){returnPyType_Type.tp_

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++ - openssl 加密库 - base64 转换

我正在使用opensslBIO对象将二进制字符串转换为base64字符串。代码如下:voidToBase64(std::string&s_in){BIO*b_s=BIO_new(BIO_s_mem());BIO*b64_f=BIO_new(BIO_f_base64());b_s=BIO_push(b64_f,b_s);std::cout长度为64或72。但是输出始终为65,这是不正确的,它应该比这大得多。该文档不是世界上最好的,AFAIKbio_s_mem对象应该动态增长。我究竟做错了什么?我可能最好找到一个不提供流支持但支持base64转换的自包含C++类。流媒体支持不适合我的应用程

php - Base58 编码 Peercoin 公钥的步骤

我希望有人能帮助我应对这个挑战。我想知道用于转换的过程十六进制130字符Peercoin公钥到Peercoin地址。如果您可以阅读C++,阅读此处https://github.com/ppcoin/ppcoin/blob/master/src/base58.h#L1的源代码,将会有所帮助。我需要帮助调整此代码以适用于Peercoin(我从本网站上一个问题中获得此代码)。让我们以此为例,130字符公钥:04D166177BBC050D53ABD5197A1A0D1DAC31B14795E0A1C2267918FBEAF28DDCBB200D313541E8E5374E573FA570D8

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++ - 由于类型不完整,在 static_assert 中使用 std::is_base_of 失败

我想做的是让一些类继承自extention类。问题是extention类必须知道它正在扩展哪个类。这可以像这样简单地实现:templateclassExtention{public:voidcheck()const{std::cout::value{};classBar:publicExtention{};Foo和Bar类显示了扩展的好坏用法。Foo().check();→Extentionisvalid:trueBar().check();→Extentionisvalid:false我想在编译时检查模板的有效性,这让我写了templateclassExtention{static_

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