草庐IT

boost-pool

全部标签

c++ - Boost Program_Options 抛出 "character conversion failed"

我在Ubuntu14.04上,使用CMake和CLion。我正在尝试使用程序选项,以下代码取自其文档中的示例:#include#includeintmain(intac,char*av[]){namespacepo=boost::program_options;usingnamespacestd;po::options_descriptiondesc("Allowedoptions");desc.add_options()("help","producehelpmessage")("compression",po::value(),"setcompressionlevel");po::

c++ - 没有 Boost 的现代 C++ 中的 bimap 实现

这个问题之前有人问过here我承认,但现在是4年前了,所以我敢要求更新:我需要一种方法来将元组/对添加到容器并有效地搜索左右元素。Boost有bimap和multi_index,它们完全符合我的要求,但我想知道在普通现代C++-11/14中推荐的替代方案是什么,以防您不想要引入对boost的依赖(无论出于何种原因)。链接中的一个答案表明不需要s.th。由于透明比较器,它不再像bimap了。接受的答案建议将std::map组合到key1->key2和key2->key1.我真的不知道透明比较器如何在这里帮助我,我只是好奇是否有一些你应该这样做以及为什么-解决方案。你能提供一些提示/链接吗

c++ - 如何为 boost::program_options 的位置选项添加描述?

我想用boost_program_options创建一个位置列表程序选项,不允许命名程序选项(如--files)。我有以下代码片段:#include#include#include#includenamespacepo=boost::program_options;intmain(intargc,constchar*argv[]){po::options_descriptiondesc("Allowedoptions");desc.add_options()("help","producehelpmessage")("files",po::value>()->required(),"l

c++ - 使用 boost::filesystem 添加 header 后,不再找到来自 google test 的单元测试

我有一个使用谷歌测试框架的单元测试项目,我的测试工作正常。但是现在我添加了boost::filesystem标题类似#include之后我的项目链接和编译正常,但是根本没有找到测试,当我运行测试时它给了我-Processfinishedwithexitcode-1073741515(0xC0000135)Emptytestsuite.如果我有这段代码:#includeTEST(Test,Test1){ASSERT_FALSE(true);}它工作得很好并找到失败的测试用例,但是如果我像这样添加boostheader:#include#includeTEST(Test,Test1){AS

c++ - 为什么 Boost::multiprecision::sqrt(1) 返回 0?

Boost::multiprecision::sqrt(1)似乎返回0#include#include#includeusingstd::cout;usingstd::endl;intmain(){namespacemp=boost::multiprecision;mp::cpp_inti(1);cout输出:我==1mp::sqrt(i)==0我希望sqrt(1)==1。我在coliru上得到了相同的结果在我本地安装的gcc和Boost1.62上。这会发生在其他人身上吗?我是否遗漏了什么或者这是一个错误? 最佳答案 是的,这绝对是

c++ - BOOST_PP_DEFINED 可以实现吗?

是否可以编写一个类似函数的C预处理器宏,如果定义了参数则返回1,否则返回0?让我们将其称为BOOST_PP_DEFINED,类比其他boost预处理器宏,我们可以假设它们也在发挥作用:#defineBOOST_PP_DEFINED(VAR)???#defineXXXBOOST_PP_DEFINED(XXX)//expandsto1#undefXXXBOOST_PP_DEFINED(XXX)//expandsto0我希望将BOOST_PP_DEFINED的结果与BOOST_PP_IIF一起使用:#defineMAGIC(ARG)BOOST_PP_IIF(BOOST_PP_DEFINED(

c++ - 如何使用 boost::python 创建和使用 Python 对象的实例

假设我有一个像这样的Python类:classMyPythonClass:defFunc1(self,param):returndefFunc2(self,strParam):returnstrParam如果我想在我的C++代码中嵌入包含该类的Python脚本,通过我的C++代码创建该对象的实例,然后调用该python对象的成员,我该怎么做?我想应该是这样的:namespacepython=boost::python;python::objectmain=python::import("main");python::objectmainNamespace=main.attr("__di

c++ - boost 梅森扭曲器 : how to seed with more than one value?

我正在使用boostmt19937实现进行模拟。模拟需要可重现,这意味着存储RNG种子并可能在以后重复使用。我正在使用windowscryptoapi生成种子值,因为我需要种子的外部来源,而不是因为任何特定的随机性保证。任何模拟运行的输出都会有一个注释,包括RNG种子-所以种子需要相当短。另一方面,作为模拟分析的一部分,我将比较几次运行——但为了确保这些运行实际上不同,我需要使用不同的种子——所以种子需要足够长以避免意外碰撞。我已经确定64位的播种应该足够了;在大约2^32次运行后发生碰撞的可能性将达到50%——这个概率足够低,以至于由它引起的平均错误对我来说可以忽略不计。仅使用32位

c++ - 在模块化程序中使用 Boost.Program_options

我使用的代码由一组模块组成,编译成单独的库。反过来,库以不同的组合链接以构建不同的二进制文件。所以,这是非常有序的。不同的模块使用不同的命令行参数,我想使用Boost.Program_options进行解析。由于命令行参数集取决于链接在一起的库,我事先不知道所有参数,因此无法将它们添加到program_options::options_description。如何使每个模块能够添加其命令行参数并稍后读取它们?谢谢 最佳答案 例如通过使用options_description的成员函数add(constoptions_descript

c++ - boost Weak_Ptr : Destruction is more expensive than expected

无论出于何种原因,我们看到销毁弱指针的成本相当高。这是罪魁祸首代码:~weak_count()//nothrow{if(pi_!=0)pi_->weak_release();//Consumesahugechunkofourtime.#ifdefined(BOOST_SP_ENABLE_DEBUG_HOOKS)id_=0;#endif}我们没有处于Debug模式,调试Hook也没有启用。弱释放消耗了非常多的时间。这是一个已知的问题?我们做错了什么吗?boost版本:1.36编译器:VS2008编译器套件。不幸的是,由于各种原因,我们被锁定在这个Boost版本中,所以我更想知道这些奇怪的