草庐IT

boost-lambda

全部标签

c++ - boost::msm - 一种获取状态的字符串表示形式(即 getName)的方法?

我正在尝试使用boost::msm库在我的代码中创建一个状态机。有谁知道获取状态的字符串名称(不是intid)的方法?我正在尝试将其用于日志记录/调试目的。例如在no_transition函数中,我得到了状态ID,但我试图得到一个名称以便于阅读:templatevoidno_transition(Eventconst&e,Fsm&fsm,intstateId){//ThisiswhatI'mtrying:autostate=fsm.get_state_by_id(stateId);//Thisreturnsaboost::msm::front::default_base_state.A

c++ - Boost.Spirit.Qi - 规则开头的错误

如何检测规则开头的错误?例如,考虑MiniXMLexample包含在文档中。如果我向解析器提供如下内容:thisisanerror然后我得到:Error!Expectinghere:""Error!Expectinghere:""Parsingfailed.那很好,但接下来考虑喂它:element>thisisanerror我得到的是非常通用但不太有用的:Parsingfailed.我如何修改规则以提供信息的方式报告错误? 最佳答案 您希望需要文档根级别的元素。其他消息是由失败的期望点生成的。您会希望在开始时有一个额外的期望值。我会

c++ - 我如何扩展 boost spirit 语法

事情是我做了一个对任务有用的语法,但是现在任务已更改,我需要定义新规则。但我不想修改已有的语法喜欢创建一个新的语法,它使用我现有的没有代码的语法重复,所以我只需要定义我需要的新规则。我尝试了一些东西像这样,但不起作用:structNew_grammar:Old_grammar{New_grammar():New_grammar::base_type(Command_list){Command_list%=qi::eps>>+Commands;Comandos%=oneoldCommand|NewCommand;NewCommand=("NewCommand">>stmt)[qi::_v

c++ - 在语义 Action 中 boost spirit 改变变量值

我想在语义操作中更改局部变量值,如下所示:#defineBOOST_SPIRIT_USE_PHOENIX_V3#include#include#includenamespaceqi=boost::spirit::qi;namespacespirit=boost::spirit;namespaceascii=boost::spirit::ascii;usingboost::phoenix::ref;usingboost::phoenix::bind;voiddummy(conststd::vector&v,int&var){var=7;}templatestructx_grammar:p

c++ - 默认初始化 boost::optional

有没有办法在不提供T的名字的情况下默认初始化一个boost::optional变量?structMyStruct{inta;};intmain(){boost::optionalopt;opt=MyStruct();//我的目标是在我只想默认初始化时省略提供结构名称​​opt。 最佳答案 如果您的编译器支持可变参数模板并且您使用的是Boost1.56或更高版本,请使用emplace()没有参数:opt.emplace();如果不满足任何一个条件(没有可变参数模板的编译器或较旧的Boost)使用不带参数的in_place工厂:opt=

c++ - 通过 boost 信号 2 的观察者模式

所以,我已经阅读了Boost.Signal2的文档,并且进行了一些谷歌搜索,但我还没有完全找到我需要的东西。我拥有的是一个Controller和一个View概念。Controller将向View发送数据以供其呈现。我想要的是我的Controller调用Controller::Update并在View中触发OnUpdate函数。Controller和View应该是分离的可以发出Controller上的信号以在View中执行Slots这是我到目前为止尝试过的代码:classListener{public:virtualvoidOnUpdate(){};};classView:Listene

c++ - Lambda 函数,奇怪的行为

假设我们在全局命名空间中声明了以下lambda:autoLess=[](inta,intb)->bool{returna以及以下使用此lambda的代码:templatestructfoo{foo(intv){}booloperator&)const{returnT(1,2);}};intmain(){typedeffoobe_less;priority_queuedata;}如你所见,我使用Less作为结构foo的模板参数.对于g++4.9.2,此代码无法编译:test1.cpp:13:21:error:nomatchingfunctionforcallto'::__lambda0(

c++ - std::equal_range 与 lambda

假设我有一个字符串vector,我想找到所有以'a'开头的字符串,所以我可以这样做:structcmp{booloperator()(conststd::string&s,charc)const{returns.front()strings;...std::sort(strings.begin(),strings.end());autorange=std::equal_range(strings.begin(),strings.end(),'a',cmp{});...这种方法容易出错,容易出错(比如我觉得第二种方法应该是c),而且代码重复。那么是否可以使用通用lambda而不是使用2种

c++ - 如果在 user.hpp 中定义了 BOOST_NO_EXCEPTIONS,为什么不能编译 boost::shared_ptr

我有一个嵌入式系统,想在这个系统中使用boost,但需要禁用异常,因为我不想支付异常成本。boost给了一个user.hpp和可设置的宏选项BOOST_NO_EXCEPTIONS和BOOST_NO_EXCEPTION_STD_NAMESPACE,但是boost::shared_ptr不能编译(更准确的说,不能链接)如果定义了这两个宏。shared_ptr_boost.cpp:(.text._ZN5boost6detail12shared_countC2IiEEPT_[_ZN5boost6detail12shared_countC5IiEEPT_]+0x7a):undefinedrefe

c++ - 为什么我们需要为 lambda 中的引用捕获引用?

考虑一下:classTestLambda{public:std::vectordata;};voidtest_lambda(TestLambda&obj){[=]()mutable{obj.data.push_back(0x01);}();}intmain(){TestLambdatst;tst.data.push_back(0x99);test_lambda(tst);//tst.dataisunchangedatthispointreturn0;}在调用test_lambda后,我希望看到tst.data发生变化,但事实并非如此。要查看更改,我必须创建再次传递obj引用的lambd