草庐IT

tok_iter

全部标签

C++ : List iterator not incrementable

尝试删除列表的最后一个元素时出现此错误。我调试了代码并且能够找出导致它的原因和位置,这是我的代码:for(Drop_List_t::iteratori=Drop_System.begin();i!=Drop_System.end()&&!Drop_System_Disable;/**/){if(Player->BoundingBox.Intersect(&(*i)->BoundingBox)){i=Drop_System.erase(i);}++i;//Listiteratorcrasheshereiflastentrywasdeleted}我不知道我做错了什么……有什么建议吗?

c++ - iterator_traits<InIter>::value_type 的创建是否会在传递时触发遵从? (异常测试)

我在故意为不特别遵守迭代器的函数抛出异常(出于测试目的)时遇到了麻烦。要了解我在做什么,请带上我的decorator_iterator结构:structdecorated_iterator:boost::iterator_adaptor,BaseIterator,boost::use_default,IteratorTag>{//....private:friendclassboost::iterator_core_access;/*usedtothrowanexceptionupondereference*/typenamebase_type::referencedereferenc

c++ - 如何在 boost::transform_iterator 中使用 phoenix 表达式?

和往常一样,这个问题是错误的。实际问题是:为什么transform_iterator不使用传统的result_of元函数来确定返回类型,而是直接访问UnaryFunc::result_type。发布了一个解决方法的答案。具体来说,是否有办法使phoenix表达式按照std::unary_function概念的预期公开result_type类型?boost::transform_iterator似乎预料到了这一点,从它的src来看,我没有看到一个简单的解决方法。下面是一些重现我遇到的问题的代码:#include#include#include#includeusingnamespaceb

c++ - 为什么 reverse_iterator 有一个默认的构造函数?

我刚刚学习STL,reverse_iterator让我感到困惑。它有一个默认构造函数,但我不知道如何使用它。我试过:reverse_iteratorr{};r--;然后程序崩溃了。我认为这种用法没有意义,而且很容易导致崩溃,那么为什么允许使用默认构造函数呢? 最佳答案 std::reverse_iterator是bidirectionaliterators,它们有一个明确的要求,即它们是可默认构造的。至于whybidirectionaliteratorsaredefault-constructible,这主要是因为几乎可以肯定它们实

c++ - 循环 : future iterations overwrite results of previous iterations 中的 If-else 条件

我尝试在items列表中突出显示selectedItem及其children。constQListitems=/*...*/;Item*selectedItem=/*...*/;Q_FOREACH(Item*item,items){if(selectedItem==item){item->setHighlightEnabled(true);//Highlightselecteditem}else{item->setHighlightEnabled(false);//De-highlightotheritems}}item->setHighlightEnabled方法递归地对子项执行相同

c++ - std::equal 与 reverse_iterator

将reverse_iterator与std::equal一起使用是否合法?例如,这些是否合法?std::equal(v.begin(),v.end(),w.rbegin())std::equal(v.rbegin(),v.rend(),w.begin())std::equal(v.rbegin(),v.rend(),w.rbegin()) 最佳答案 所有都是有效的,因为反向迭代器是,事实上,正向迭代器。“反向迭代器”不是迭代器类别。记住一些迭代器类别:可以取消引用(*)和递增(++)的迭代器是前向迭代器。也可以递减的前向迭代器是双向

c++ - 运算符 != 对于 std::reverse_iterator c++ 是不明确的

我正在开发一个实现自己的迭代器的容器,我将其与std::reverse_iterator一起使用以获得反向迭代功能。我可以将反向迭代器分配给rend或rbegin,但是当我尝试访问它的任何功能(例如!=或==)时,我得到了这个:1IntelliSense:morethanoneoperator"!="matchestheseoperands:functiontemplate"boolstd::operator!=(conststd::reverse_iterator&_Left,conststd::reverse_iterator&_Right)"functiontemplate"bo

c++ - 如何使用 libc++ istream_iterator 读取文件中的 0xFF?

考虑以下示例代码:#includeusingnamespacestd;intmain(){istreambuf_iteratoreos;istreambuf_iteratoriit(cin.rdbuf());inti;for(i=0;iit!=eos;++i,++iit){cout以及包含以下内容的输入文件:“foo\xffbar”:$hexdumptestin0000000666f6fff6261720000007现在使用clanglibc++与gnulibstdc++进行测试:$maketestclang++-std=c++11-stdlib=libc++-Wall-stdlib=

c++ - boost::split 与 boost::iter_split 之间的区别

boost::split和boost::iter_split函数有什么区别? 最佳答案 boost::split将拆分后的字符串复制到SequenceSequenceT(例如std::vector)。boost::iter_split地点iterators(特别是迭代器范围)到SequenceSequenceT.这实际上意味着两件事:使用split将创建拷贝,因此原始字符串不会看到对返回的字符串容器的任何更改。此外,您无需担心迭代器失效。使用iter_split将返回一个迭代器范围的容器,因此,修改这些迭代器指向的内容也会修改原始字

c++ - 为什么迭代器在 VS2010 中导致调试非常缓慢,即使 _HAS_ITERATOR_DEBUGGING、_SECURE_SCL、_SECURE_SCL_THROWS 设置为 0

我一直试图找出为什么在Debug模式下调试我们的程序需要这么长时间。在使用xperf查看堆栈的样子后,很明显我们在迭代器和STL容器上花费了大量时间。我在谷歌上搜索了一会儿,找到了选项_HAS_ITERATOR_DEBUGGING=0_SECURE_SCL=0_SECURE_SCL_THROWS=0我用#define在代码中设置所有这些#define_HAS_ITERATOR_DEBUGGING0#define_SECURE_SCL0#define_SECURE_SCL_THROWS0但这似乎没有用,所以我尝试使用visualstudio项目中的预处理器定义,但似乎仍然没有帮助。我已经