草庐IT

boosting

全部标签

c++ - 使用带有 `make check` 的 Boost 单元测试框架 (UTF)

我的C++应用程序有各种基于shell的独立程序集成测试以及应用程序API的源代码单元测试。测试通过makecheck目标运行,该目标通过Autotools(autoconf、automake)生成,comewithatest-driverandalogparser.我已经开始采用Boost单元测试框架来更好地管理单元测试套件。有没有办法在makecheck目标下同时运行验收测试和单元测试(使用BoostUTF和标准TAP测试)?我的Makefile.am看起来像这样:check_PROGRAMS=test1test2SOURCES=test1.cpptest2.cppCC=g++TE

c++ - 在 C++ 中自动绑定(bind) boost::thread?

做的时候:std::vectorvec;intnumber=4;boost::threadworkerThread(&Method,number,vec)givenamethod:templatevoidMethod(intn,std::vector&vec){//doesstuff}为什么我必须手动做:boost::threadworkerThread(&Method,number,boost::ref(vec))?为什么它不通过引用自动传递它?Edit::理论上boost::thread是否有可能做一些宏元编程来调整它,因为C++没有内置反射/内省(introspection)的方

c++ - 使用 boost::mpi 的 mpi 中的消息大小是否有限制?

我目前正在openMPI之上使用boost::mpi编写模拟,一切运行良好。但是,一旦我扩大系统规模,因此必须发送更大的std::vectors,我就会出错。我已将问题简化为以下问题:#include#include#include#include#include#includenamespacempi=boost::mpi;intmain(){mpi::environmentenv;mpi::communicatorworld;std::vectora;std::vectorb;if(world.rank()==0){for(size_ti=1;i打印出来:a1B1a2B2a4B4.

python - 在一个共享对象中 boost python 多个模块

我正在尝试通过boostpython创建一个包含多个模块的包。原因是我们想要公开一个非常大的API,将它分组到不同的模块中以便于使用和保留python内存使用是有意义的。另一方面,我们被迫(出于超出这个问题范围的原因将其编译成单个共享对象)所以我用boostpython创建了一个导出多个模块的包,如下所示:voidexportClass1(){namespacebp=boost::python;//maptheIOnamespacetoasub-module//make"frommyPackage.class1import"workbp::objectclass1Module(bp::

c++ - Boost::Spirit - on_error 不打印

我正在尝试使用Boost::Spirit::qi的on_error机制来找出解析失败的原因。我在on_error函数处设置了一个断点,该函数正在被调用,但没有输出(nada、nothing、void、...)。简单的on_error:on_error(level1,boost::phoenix::ref(std::cout)复杂的on_error(来自不同网站):on_error(start,boost::phoenix::ref(std::cout)(qi::_3,qi::_2)这是我的类,包含简单的on_error:templatestructEvent_Compound:qi::

c++ - 用 boost::spirit 解析成一个 vector<vector<double>>

我的目的是将逗号分隔的值列表解析为嵌套vector。这个列表是二维的。基本问题是:是否可以用boost::spirit解析成vector的vector?类似于“牵引力”下的表格:''RPM0,5000,10000,15000,20000,25000''Temp'-40.,0.,20.,40.''Traction200.,175.,170.,165.,160.,150.200.,175.,170.,165.,160.,150.165.,165.,160.,155.,145.,145.160.,155.,150.,145.,145.,140.'下一步,我想读入4维数据,但目前我正在努力处理

c++ - Boost 或标准库是否提供了一种方法来检查转换是否无损?

我正在寻找一个标准库或Boost函数,它们可以无损地将数字转换为另一种基本类型,并以某种方式告诉我转换是否无损(如果不是,则抛出异常)。以下是一些示例:autox=lossless_cast(1u);//ok,doublecanrepresent1autox=lossless_cast(1.2);//fail,intcan'trepresent1.2autox=lossless_cast(1E200);//fail,intcan'trepresent1E200boost::numeric_cast接近于它会拾取超出目标类型数值范围的转换,但如果它们是无损的但在目标类型内则不会(参见我的

python - 关于boost-python : dyld: Symbol not found: _PyBaseObject_Type

当我运行我的代码时,我遇到了一个关于boost-python的问题。就像这样:dyld:Symbolnotfound:_PyBaseObject_TypeReferencedfrom:/opt/local/lib/libboost_python-mt.dylibExpectedin:flatnamespace我的项目几个月前就可以正常运行了。但是现在,当我重新配置环境时,它无法运行。-几个月前,我用homebrew配置环境,就像这样:brewinstallboostbrewinstallpythonbrewinstallboost-pythonbrewinstallopencv(Myp

c++ - 中断 boost::asio 同步读取?

我正在使用asio同步套接字从后台线程通过TCP读取数据。这被封装在“服务器”类中。但是,我希望线程在调用此类的析构函数时退出。问题是对任何读取函数的调用都会阻塞,因此无法轻易终止线程。在Win32中有一个API:WaitForMultipleObjects可以完全满足我的要求。如何使用boost实现类似的效果? 最佳答案 在我们的应用程序中,我们设置了“终止”条件,然后使用自连接到线程正在监听的端口,以便它醒来,记录终止条件并终止。您还可以检查boost实现-如果他们只是在套接字上进行普通读取(即,不在内部使用WaitForMul

c++ - boost pool_alloc

为什么boost::fast_pool_allocator建立在单例池之上,而不是每个分配器实例一个单独的池?或者换句话说,为什么只提供那个,而不是每个分配器都有一个池的选项?那样做会不会是个坏主意?我有一个类在内部使用大约10种不同的boost::unordered_map类型。如果我使用了std::allocator,那么在它调用delete时所有内存都会返回给系统,而现在我必须在某些时候对许多不同的分配器类型调用release_memory。我自己推出使用池而不是singleton_pool的分配器是否愚蠢?谢谢 最佳答案 分