C++我有以下迭代循环:for(it=container.begin();it!=container.end();++it){//mycodehere}我想提前结束这个迭代1元素。我已经尝试了以下但它没有编译:for(it=container.begin();it!=container.end()-1;++it){//subtract1//mycodehere}如何做到这一点?谢谢。 最佳答案 您可以在std::prev(s.end())之前迭代一个,其中s是您的集合,注意容器可能是空:#include//forstd::preva
我正在尝试获取给定集合的所有元素的地址并将它们复制到std::set。基本上,而不是std::sets1;std::copy(first1,last1,std::inserter(s1,s1.begin()));我想插入他们的地址。像这样的东西:std::set>s1;std::copy(reference_iterator(first1),reference_iterator(last1),std::inserter(s1,s1.begin()));在这里,reference_iterator将是一个迭代器,返回其元素的地址,而不是元素,这与boostindirect_iterato
这个完美的程序在VisualStudio2013的Debug模式下失败:#include#include#includeusingnamespacestd;voidmain(){vectorv={3,1,4,1,5,9,2,6,5,3};for(autoiFrom=v.cbegin(),iTo=iFrom+5;iFrom!=v.cend();iFrom=iTo,iTo+=5)coutvectoriterator+offsetoutofrange断言失败。它失败是因为iTo>v.cend(),这在这里是无害的。调试器测试没有被取消引用的迭代器的值有什么意义?顺便说一句,我知道我可以将上面
我想知道是否可以通过仅访问容器内的对象来获得容器内对象的迭代器(例如std::vector),例如通过引用(这意味着我们可以使用&运算符访问指向它的指针)。例如,通常我们将迭代器声明为std::vector::iterator=vec.begin();或std::vector::iterator=next(vec.begin(),idx);但在第一个示例中,我们很可能要按顺序遍历容器,而在第二个示例中,我们知道所需对象的索引。我想知道我们是否可以在不知道对象驻留在容器中的哪个索引的情况下获得对象的迭代器,但如果我们确实有一个引用或指向它的指针,如上所述。似乎已经有人问过这个问题了her
我需要std::list中最后两个元素的别名。最后一个很简单(.back()),但是我应该如何得到它之前的那个呢?我的第一个想法是:在最后一个元素(.end())之后获取一个迭代器,并将它向左移动两次。这是我“制作”的内容:&last_but_one=*----myList.end(),虽然它有效,但我个人觉得它有点模糊,如果我在别人的代码中看到它,我认为我不会轻易解析它1。通读thisanswer显示了一些其他(过于)冗长的方法2:autoiter=n.end();std::advance(iter,-2);&last_but_one=*iter;//thisisoverkill!/
我正在努力了解更多有关C++中的STL迭代器的信息。我了解不同的数据结构如何具有不同的迭代器,但我不明白为什么有些迭代器不是RandomAccess。例如,为什么LinkedList迭代器不是随机访问迭代器?我知道LinkedList本身不是“随机访问结构”,但我们不能实现迭代器来产生随机访问结构的错觉吗?例如,LinkedList有一个双向迭代器,它没有定义+或+=运算符,但定义了++运算符。难道我们不能只定义+和+=运算符,使用类似的东西:iteratoroperator+=(intsteps){for(inti=0;ioperator++();}}在查看了RandomAccess
我有一个std::shared_ptr的容器。我想使用std::equal比较两个容器。类A定义了operator==。我想使用其运算符==比较每个元素是否等效,而不是shared_ptr中定义的那个。我是否需要让一个函数或函数对象传递给equal?或者是否有一些内置的东西会更简单(比如中定义的东西)? 最佳答案 您将需要一个函数或一个函数对象或一个lambda表达式(因为您可以使用std::shared_ptr,所以您已经启用了C++0x的某些部分)。中没有任何内容帮助你,但有一些东西在提升:indirectiterator#in
std::vectorv;for(size_ti=init;i输出:4095000我不明白为什么这个printf会这样?init或pageSize都不为0。我知道%d对unsignedlonglong无效,但令我困扰的是当参数的顺序改变时printf的行为改变。 最佳答案 NeitherinitorpageSizeis0.%d也不是适合64位值的格式字符串说明符,我敢打赌:-)很有可能,您需要使用%ld(如果您的longs是64位)或%lld(如果您的longlongs是64位)或来自最新C标准的固定宽度说明符宏,我永远无法记住它们
背景资料:我和几个friend在ochsfml和box2d的帮助下用C++构建这个平台游戏用于学校作业。其中一项要求是我们遵循“MVC模式”。我们为模型创建了Bullet和Character类。以及BulletView和CharacterView(都继承了抽象类sf::Drawable)作为View。与其重复绘图代码,不如像这样使用drawBullets和drawCharacter两种方法voidWorldView::drawBullets(){std::vector::iteratorit;for(it=bullets.begin();itdraw(**it);}voidWorldV
我应该为一个只是vector包装器的类编写迭代器吗?我的类Record中唯一的私有(private)成员是vector。我希望能够做到这一点:for(auto&elem:record){//dosomethingwithelem}其中record是Record类型。为此,我需要实现迭代器对于记录类。但是,我也可以这样做:for(auto&elem:record.elems){//dosomethingwithelem}其中record.elems是我提到的vector。但是这样我需要将其公开。另一种方法是:for(auto&elem:record.getElems()){//dosom