草庐IT

boost_thread

全部标签

c++ - 如何正确链接 boost::mpl::inherit_linearly 和 boost::mpl::inherit 以便解析占位符?

假设我有这些类型:templateclassStorage>structAbstractFactoryUnit{virtual~AbstractFactoryUnit(){}virtualtypenameStorage::StoredTypedoCreate(Storage)=0;};和templateclassProductStorage,templateclass>classUnit=AbstractFactoryUnit>structAbstractFactory:boost::mpl::inherit_linearly>>::type{typedefTypeSequencePr

c++ - Boost协程断言失败

为了在boost中尝试新的协程功能,我创建了以下程序:#include#include#includetypedefboost::coroutines::coroutinecoroutine_t;voidf(coroutine_t::caller_type&ca){std::vectorvec={1,2,3};for(inti:vec){charc=ca.get();std::cout代码基于samplecodefromthedocs.我的构建命令如下:$g++-std=c++11-otest-I/usr/local/include-L/usr/local/libmain.cpp/us

c++ - `boost::signals2` 中的信号签名是如何实现的?

我在我的项目中使用boost::signals2已有一段时间了。令我遗憾的是,我仍然不明白它们是如何在幕后实现的。我的问题已经从信号的定义开始了。如何定义如boost::signals2::signal处理了吗?我可以从实现细节中看出,签名变成了一个模板参数,它被恰本地命名为Signature。但是,我不明白语法。C++标准是否允许这种语法?以这种形式提供的信号如何“存储”函数签名?我已经尝试查看源代码,但无法找到此语法的解释。任何帮助将不胜感激。 最佳答案 是的,这种语法是允许的;它表示的类型是一个对采用bool和double并返

c++ - 替代 std::this_thread::sleep_for()

我有一个循环,我想确保它在每个循环中运行(大约)固定的时间量。我正在使用sleep_for来实现此行为,但我也希望程序能够在不完全支持标准线程库的环境中编译。现在我有这样的东西:usingnamespacestd;usingnamespacestd::chrono;//while(!quit){steady_clock::time_pointthen=steady_clock::now();//...doloopstuffsteady_clock::time_pointnow=steady_clock::now();#ifdefNOTHREADS//versionforsystemsw

c++ - 在进程间内存中使用 boost::optional 是否安全?

请考虑以下结构:structThingThatWillGoInSharedMemory{boost::optionalopt_value;};我正在使用boost::interprocess来创建共享内存区域。我对boost::optional的理解是它是一个有区别的union,而不是一个可为空的指针。作为一个反例,像std::map和std::vector这样使用堆的东西需要一个显式分配器才能在进程间内存中使用它们,但是boost::optional,我相当确定不使用堆并且等同于写作:structThingThatWillGoInSharedMemory{boolvalue_init

c++ - 将 std::exception_ptr 转换为 boost::exception_ptr

我想使用boost::promise::set_exception()需要一个boost::exception_ptr。问题是boost:exception_ptr似乎只有在我用enable_current_exception包裹所有我的抛出时才能正常工作,我想避免这种情况。(无论如何,我无法为第3方图书馆做到这一点。)我在整个代码中使用std::exception_ptr/std::current_exception,所以我正在寻找一种方法来传递std::exception_ptr,其中boost:exception_ptr是预期的。执行以下操作但编译的东西:boost::excep

c++ - 无法让 BOOST odeint 与 Adams-Bashforth-Moulton 一起工作

我在使用BOOSTodeint库中的Adams-Bashforth-Moulton方法时遇到了一些问题。我在Bulirsch-Stoer上取得了成功,但出于某种原因,每当我尝试使用大于2的阶数时,Adams-Bashforth-Moulton只会返回nan。如果我使用阶数1或2,我会得到双倍的真实答案。我已将代码缩减为:#include#include#include#includetypedefboost::arraystate_type;usingnamespaceboost::numeric::odeint;classBoost_odeint_rhs{public:Boost_o

c++ - Boost库和最近点

我可以找到点MyPoint和多边形MyPolygon之间的距离doubledist=boost::geometry::distance(MyPoint,MyPolygon)显然MyPolygon上的实际最近点必须在某处计算。有没有一种简单的方法可以得到最近的点?我在Boost文档中找不到任何内容,我相信其他人也遇到过这个问题。 最佳答案 根据source它迭代类distance_single_to_multi中多边形的所有点。它不存储迭代器,所以你可能应该这样做。您可以在comparable_distance中找到如何执行此操作示例

c++ - 使用 MPL 列表扩展 boost 变体

我正在尝试为程序提供一种向库中的变体添加新对象的方法,但我遇到了一些神秘的错误。#include#include#include#includestructInternalType1{};structInternalType2{};templatestructFoo{typedefboost::mpl::listTypes;typenameboost::make_variant_over::type>::typecontainer_;//typenameboost::make_variant_over//>::type//>::typecontainer_;};structLocalT

【神行百里】python开启多线程(threading)与多进程(multiprocessing)运行

  由于处理数据过多,程序运行很慢,就学习了一下python开启多线程与多进程的方法,虽然最后也没用上,但还是记录总结一下,以备不时之需。  传送门:进程与线程认识,进程与线程通俗理解  简言之,进程为资源分配的最小单元,线程为程序执行的最小单元1.threading库实现多线程运行  threading库中的Thread类可以方便地开启多线程运行,Thread类需要传入两个参数,target为需要执行的函数,args为函数的参数,本例中自定义的multithreading函数具有三个参数。importthreadingimporttimeimportosdefmultithreading(d