jjzjj

c++ - 振奋 spirit : What type names should be used for the built in terminals?

我正在重构一个类型系统(类型模型),它使用spirit进行字符串序列化。我正在使用类型特征的编译时建模构造。templatetype_traits{typedefboost::spirit::qi::int_parserstring_parser;}templatetype_traits{typedefboost::spirit::ascii::stringstring_parser;}在这个例子中,我展示了原始解析器,但我希望也加入规则。int4类型有效,但这是因为(home/qi/numeric/int.hpp+27):namespacetag{templatestructint_

c++ - 具有关联属性的 boost::hash_combine 的替代方案?

我正在寻找具有关联属性的hash_combine函数。例如,我希望能够依次组合值a、b、c、d以获得序列的哈希键,或者组合a和b,然后组合c和d,然后组合结果。这两种方法应该给出相同的结果。boost::hash_combine没有那个属性://a*b*c*dstd::size_tseed=0;boost::hash_combine(seed,234);boost::hash_combine(seed,62);boost::hash_combine(seed,675);boost::hash_combine(seed,916);std::cout有什么好的hash_combine函数吗

c++ - 使用 boost 1.36 和 C++ 的 RHEL4 版本问题

我正在为一个神秘的问题而苦苦挣扎我只在我的RHEL4发布版本上看到。我的一些单元测试(使用boost1.36单元测试框架)在RHEL4(gcc3.4.6)上失败并使用发布构建类型。我没有看到使用RHEL5版本或调试构建类型(gcc4.1.2、boost-1.39)的问题;我也不使用VisualStudio2005(使用boost-1.36)或2008(使用boost-1.39)在Windows32位或64位上查看它。怀疑这可能是由于一些微妙的内存问题,我继续在测试应用程序上运行valgrind(保留问题的最小情况)。这是我使用“完全,不可访问”模式运行valgrind时得到的结果:==

c++ - 使用 mpl::vector 定义 boost::variant 类型

我正在使用库boost::variant来存储大量类型。随着字数越来越多,我很快就要达到20字的极限了。在文档中,似乎可以使用mpl::vector定义变体,它允许超过20种类型(如果我是正确的,最多50种)。我试图像这样替换我的变体定义:#include#includetypedefboost::mpl::vector,relative_point,relative_point,std::string,color,group,dictionnary,reference,line,strip,text,font>variant_mpl_vec;typedefboost::make_va

c++ - boost .Python : Take possession of argument

如果我有一个函数占用其中一个参数,当我使用Boost.Python公开该函数时,是否应该使用任何调用策略?voidfunc(MyClass*obj){//Codethattakespossessionof`obj`} 最佳答案 我认为你可以使用boost::weak_ptr。usingboost::shared_ptr;usingboost::weak_ptr;func(weak_ptrwp){shared_ptrsp=wp.lock();if(sp)//spstaysaliveuntilitgoesoutofscopeorisre

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++ - Boost Serialization - 不再反序列化损坏的数据时没有 archive_exception?

几个月前我实现了一个组件,它通过UDP网络接收数据,通过Boost::Serialization反序列化它并开始处理传入的对象。在使用这个组件一段时间后发生了随机崩溃,当我发现其他人正在向我的UDP端口发送数据时我可以解决这个问题。我通过简单地在反序列化周围添加一个try/catch解决了这个问题:try{boost::archive::text_iarchiveinputArchive(incomingData);inputArchive>>givenElements;//theactualdeserialization,heretheexceptionhasbeenthrownin

c++ - 线程安全队列是一种好方法吗?

我正在寻找一种方法来优化我开发的开源项目的以下代码,或者通过将繁重的工作转移到另一个线程来boost它的性能。voidProfilerCommunication::AddVisitPoint(ULONGuniqueId){CScopedLocklock(m_mutexResults);m_pVisitPoints->points[m_pVisitPoints->count].UniqueId=uniqueId;if(++m_pVisitPoints->count==VP_BUFFER_SIZE){SendVisitPoints();m_pVisitPoints->count=0;}}以

c++ - boost::fusion::for_each 中的函数对象不同于 std::for_each

在升级到更新的编译器并解决编译器错误时,我意识到boost::fusion::for_each要求传入的函数对象具有运算符const。示例来自Boost:structincrement{templatevoidoperator()(T&t)const{++t;}};...vectorvec(1,2);for_each(vec,increment());这当然没有改变。我没有意识到它与std::for_each不同,它不要求运算符是const。structincrement{templatevoidoperator()(T&t)//noconsthere!!!{++t;}};std::v

c++ - Boost::graph Dijkstra:最初填充队列

我正在使用boost::graph及其Dijkstra实现。我想计算从一组顶点到另一组顶点的最短路径。我不想计算这些集合之间的所有可能路径。想法如下:我在一栋大楼里,入口在不同的街道上。这样我就可以在这些街道中的任何一条上开始我的旅程。但我只对最短的感兴趣。如果我使用自己的Dijkstra算法实现,我会执行以下操作:对于每个起始节点,距离映射到0将起始节点加入优先队列。虽然使用boost::dijkstra_shortest_paths_no_init很容易将距离图设置为0,但我不知道如何将节点添加到优先级队列。我查看了源代码,这似乎是不可能的。所以我正在考虑定义我自己的Combine