草庐IT

boost-uuid

全部标签

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++ - vim + C++ : insert a uuid in a guard clause

我正在尝试自动化文件注释标题。我一直在尝试弄清楚如何使用vim的autocmd将uuidgen命令的结果插入到我的header中。在页眉中,存在占位符文本,如下所示:#ifndef_UUID_#define_UUID_//Codegoeshere!#endif//_UUID_在.vimrc中填充_UUID_的自动命令行是:autocmdbufnewfile*.hexe"1,$s/_UUID_/".r!uuidgen."/g"问题出在r!uuidgen下。如何将shell命令执行的结果作为文本插入到autocmd行中?或者在vi替换命令中? 最佳答案

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版本中,所以我更想知道这些奇怪的

c++ - 如何在不先将整个文件读入内存的情况下使用 Boost::Spirit::Lex 对文件进行 lex?

我正在研究使用boost::spirit::lex编写词法分析器,但我能找到的所有示例似乎都假定您已先将整个文件读入RAM。我想编写一个不需要整个字符串都在RAM中的词法分析器,这可能吗?或者我需要使用其他东西吗?我尝试使用istream_iterator,但除非我使用constchar*作为迭代器类型,否则boost会给我一个编译错误。例如我能找到的所有示例基本上都是这样做的:lex_functor_type>lex_functor;//assumesentirefileisinmemorycharconst*first=str.c_str();charconst*last=&fir

c++ - boost::spirit::qi 和乱序变量

我正在编写一个词法分析器。它接受一个英文字符串,并将其转换为一组纬度/经度坐标。它有点像Google地球。不管怎样,我的符号表和语法都写好了,解析格式化数据也很开心。structLatLongDegrees{std::stringdirLat_;doubledegLat_;std::stringdirLong_;doubledegLong_;}例如:{"北",23.59,"东",-30.82}这是我的语法:basic=(latitude>>''>>double_>>''>>longitude>>''>>double_);其中纬度和经度是从速记罗盘方向映射到字符串(例如“e”到“East

c++ - std、boost 或其他具有隐式键的哈希表容器的广泛实现

如果我理解正确,std::map和std::unordered_map都会显式存储键(存储键/值对)。是否有其他一些现成可用的容器(std、boost或其他广泛实现)不会存储key,而是允许使用函数(即使用隐式key?)从存储的值中派生key。 最佳答案 std::set或std::unordered_set,具有适用于存储值类型的散列和/或比较函数。但是,查找将通过存储的值类型而不是键来完成,因此您还需要一种方法来根据键构造一个临时对象。 关于c++-std、boost或其他具有隐式键

c++ - boost::date_time, g++-4.7.0, 编译错误

以下代码在g++-4.7.0下出现编译错误,但在g++-4.6下编译正常。#include#includeusingnamespacestd;intmain(){boost::posix_time::ptimetime_t_epoch(boost::gregorian::date(1970,1,1));cout下面是反复看到的错误信息(编译器输出了很多信息)/usr/include/boost/date_time/local_time/local_date_time.hpp:433:84:error:useofdeletedfunctionboost::shared_ptr>::sha