草庐IT

boost-iterators

全部标签

c++ - Boost -gd 库文件

构建boost库(这样我就可以使用文件系统命名空间)后,我在stage/lib文件夹中找到了以下名称中包含文件系统的文件:libboost_filesystem-vc100-mt-1_51(838kb)libboost_filesystem-vc100-gd-mt-1_51(4210kb)注意第二个中的-gd。我还在括号中输入了尺寸。那么,有什么区别呢?我使用哪一个? 最佳答案 -gd用于库的调试版本。使用-gd-mt构建调试配置,使用-mt构建发布配置。 关于c++-Boost-gd库

c++ - 在容器中存储 boost::function 对象

我有一个KeyCallbackvector:typedefboost::functionKeyCallback我用它来存储按下键盘按钮时的所有监听器。我可以使用for_each添加它们并将事件分派(dispatch)给所有回调,但我不知道如何从我的vector中实际删除特定的KeyCallback签名。例如我想要这样的东西:voidInputManager::UnregisterCallback(KeyCallbackcallback){mKeyCallbacks.erase(std::find(mKeyCallbacks.begin(),mKeyCallbacks.end(),cal

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++ - 为什么 istream_iterator<string>(ifstream ("test.txt")) 会导致错误?

我尝试编写代码从名为“test.txt”的文件中读取字符串并将字符串写入标准输出。下面的代码运行良好:intmain(){usingnamespacestd;ifstreamfile("test.txt");copy(istream_iterator(file),istream_iterator(),ostream_iterator(cout,""));}但是,通过此修改,代码不再编译:intmain(){usingnamespacestd;copy(istream_iterator(ifstream("test.txt")),//(),ostream_iterator(cout,""

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++ : double iteration through map

我想遍历一个map,但内部循环只会遍历元素的上半部分。使用vector它看起来像这样:for(autoelement1=myVector.begin();element1!=myVector.end();++element1){for(autoelement2=element1+1;element2!=myVector.end();++element2){//mystuff}}但是对于mapelement1+1返回错误nooperatormatchesthisoperand..我相信这是因为元素在map中没有排序.那么我怎样才能正确地做到这一点呢?我目前正在使用这种需要在每个循环中进行