草庐IT

BOOST_PP_SEQ_FOLD_LEFT

全部标签

c++ - boost spirit 适合这种情况吗?

我有这样一种情况,我试图从名称-值对流中构建一个HDF复合类型(为简单起见,我们假设一个值可以是double型或字符型字符串)。需要明确的是,数字数据已经是二进制的——它不是字符串。名称提供结构信息(这是数组的一部分吗?这是嵌套复合类型的一部分吗?)。我想制作一个标记vector,使用名称信息插入标记(例如,“[”和“]”分隔数组,“{”和“}”分隔嵌套化合物),否则使用值(value)。从文档中我不清楚Spirit二进制解析器是否是处理数值的合适选择。 最佳答案 我无法判断“其余”(即非二进制数据)是否有理由使用PEG解析器生成器

c++ - 使用 boost 的 Glob 风格正则表达式模式匹配

我需要搜索与某些模式匹配的文件,该模式类似于使用boost在glob命令行中给出的模式。例如:如果输入是myFiles*.c,它应该匹配文件myFiles.c、myFiles1.c、myFiles123.c等。尝试在perl模式下使用boost::regex_match。但我必须将输入模式作为myfiles.*.c而不是myFiles*.c。我可以识别myfiles*.c并将其转换为myFiles.*.c并在perl模式下将其提供给boost::regex_match。但是输入模式可以是glob样式中的任何有效正则表达式,因为它是为命令行实用程序提供的。在boost中有什么方法可以以g

c++ - 使用 boost::asio ssl 服务器减少每次连接的内存使用

我正在使用boost::asio开发ssl服务器。我希望尽可能减少每个ssl连接的内存使用量。我的代码主要来源于boost::asio::sslexample服务器示例。这意味着我将session存储为Session类对象,它具有sslContext属性、已注册的read_handler等(与示例中的情况差不多)我能找到的所有优化都是启用SSL_MODE_RELEASE_BUFFERS和SSL_OP_NO_COMPRESSION。现在我每个连接大约55kB。但是根据thisthread,您可以将内存使用量减少到11kB。还有什么我可以做的来减少这种使用吗?操作系统:Ubuntu11.0

c++ - 使用 BOOST::associative property map 插入 boost::BIMAP ... 失败

引用我之前提出的关于boost::bimaps和boostassociativepropertymaps接口(interface)的问题here,我想为我的bimap使用Put和Get辅助函数。引用给出的示例代码here,我尝试添加以下内容,但由于断言失败而出现很长的编译错误...这是代码:#include#include#include#includeusingnamespaceboost;intmain(){typedefintvertex_descriptor_t;typedefboost::bimaps::bimapvd_idx_bimap_t;typedefboost::as

c++ - Boost graph typedef c++ 结构的前向声明

简短的问题描述:基本上我想要structType;typedefcontainerMyType;structType{MyType::sometypemember;}现在,我该怎么做?实际问题:对于BoostSuccesiveShortestPath算法,我需要将我的前向边缘映射到它们的反向。我有以下代码:structVertexProperty{};structEdgeProperty;typedefboost::adjacency_listDirectedGraph;structEdgeProperty{doubleedge_capacity;//capacity:1forforw

C++: boost::fusion::for_each 对于许多序列

目前,boost::fusion::for_each迭代单个序列的元素。我正在尝试创建一个函数,该函数将以类似的方式工作,但具有许多序列,并将遍历序列之间的所有可能组合。例如,如果我有三个序列S1、S2、S3,我想创建一个这样的仿函数structmy_functor{templatevoidoperator()(x&el1,y&el2,z&el3){...}}然后调用for_each(s1,s2,s3,my_functor())//appliesthefunctortoallcombinationsofelementsofs1,s2,s3其中s1、s2、s3是S1、S2、S3的实例。我

c++ - 如何在进程运行时捕获标准输出并打印到控制台和文件 (C++/Boost.Process)

我正在开发一个使用Boost的C++Process库启动子进程的应用程序(http://www.highscore.de/boost/process0.5)并使用以下代码将该过程中的标准重定向到一个文件:boost::process::initializers::bind_stdout(boost::iostreams::file_descriptor_sink在这里)上述解决方案和代码运行良好。但是,现在,我需要能够将子进程的标准输出到文件和控制台。我找到了下面的代码,它似乎可以完成这项工作:#include#include#include#includeusingnamespace

c++ - Boost 中的关键字列表运算符

我正在尝试解析一个属性顺序无关紧要的对象。例如解析employeeemployee{surname="doe",firstname="john",age=30}应该和一样employee{age=30,firstname="john",surname="doe"}所以理想情况下我的规则应该是这样的(不要介意缺少正式定义)unordered_rule%=lit("employee")>>"{">>kwd("surname")["=">quoted_string]/kwd("age")["=">int_]/kwd("firstname")["=">quoted_string]/kwd("a

c++ - boost::asio::io_service::run 在没有工作时不返回

来自Asio文档Therun()functionblocksuntilallworkhasfinishedandtherearenomorehandlerstobedispatched,oruntiltheio_servicehasbeenstopped.在下面的代码片段中,Asio除了调试输出(立即计算)外没有任何工作,但run()不返回。#defineBOOST_ASIO_ENABLE_HANDLER_TRACKING#include#include#includeintmain(){namespaceasio=boost::asio;asio::io_serviceios;asi

c++ - boost::posix_time::time_input_facet 可以处理非标准的小数秒分隔符吗?

我正在尝试从文本文件中解析日期时间。时间戳具有微秒精度,但由于我无法控制的历史原因,它们是使用冒号而不是点来分隔小数秒部分创建的,例如:2015/05/0503:10:43:537408代替2015/05/0503:10:43.537408我能够使用以下代码解析这些时间戳而不保留小数秒:#include#include#includenamespacebt=boost::posix_time;conststd::stringinputString="2015/05/0503:10:43:537408";conststd::stringinputFormat="%Y/%m/%d%H:%M