vector iterators incompatible

字面翻译迭代器类型不兼容

今天同事遇到的这个问题算是一个习惯性写法的问题。描述一下代码:

struct Track{};

class BaseTrack

{

std::vector<Track> GetTrackSourceList();

};

问题所在:

void func(BaseTrack bt)

std::vector<Track>::iterator it = bt.GetTrackSourceList().begin();

for(; it != bt.GetTrackSourceList.end();++it)

重点是红色部分,传值并非传引用,没Get一次就是一块栈的空间,无法进行比较。但是这里报的错误(迭代器不兼容),不是很理解。

网上有很多这个问题的文章,虽然不是今天遇到的这个问题的原因,但是也可以很好的给与参考。

截取其中有参考价值的部分:

void _Compat(const _Myiter& _Right) const

{   // test for compatible iterator pair

if (this->_Getcont() == 0                            // 判断_Myproxy是否为0,为0则报错,否则获取所属容器

|| this->_Getcont() != _Right._Getcont())   // 判断两个向量的型类是否一致

{    // report error

_DEBUG_ERROR("vector iterators incompatible");

_SCL_SECURE_INVALID_ARGUMENT;

}

}

const _Container_base12 *_Getcont() const

{   // get owning container

return (_Myproxy == 0 ? 0 : _Myproxy->_Mycont);

}

在这里我发现我那段代码中的_Myproxy是为0的,也就是说我们的类型应该不存在问题,而是向量的“链条”断掉了。

从库的跟踪中我发现向量是使用名称为“_Myproxy”、“_Mynextiter”这两个指针来寻找与之相邻的值的,在我们定义一个向量时,它便初始化一个“_Myproxy”

解决方法:改成传引用。或者使用数组存储Get的信息,然后最后将操作完的数组再set回去。

网上还有很多因为erase时被删除之后的所有迭代器无效导致的错误,解决方法:使用erase的返回值记录迭代器的下一个位置

参考地址:

http://blog.csdn.net/olanmomo/article/details/38420907

http://stackoverflow.com/questions/8421623/vector-iterators-incompatible

时间: 2024-10-25 20:05:32

vector iterators incompatible的相关文章

关于list iterators incompatible/vector iterators incompatible 报错总结

STL有三大核心部分:容器(Container).算法(Algorithms).迭代器(Iterator),容器适配器(container adaptor),函数对象(functor),除此之外还有STL其他标准组件,如果你使用容器不当,就会发生list  iterators  incompatible/vector iterators  incompatible 的错误,报错如图: 如果你trace代码,你可以看到如下代码: bool operator==(const _Myiter& _Ri

Cocos2d-x Vector——vector iterators incompatible

***************************************转载请注明出处:http://blog.csdn.net/lttree****************************************** 使用 cocos2d-x 中的 Vector的时候, 在删除某个对象的时候出现了个错误,很崩溃啊..... Vector<Bullet*>* bullets; // 遍历每个bullet,让他们自己更新 for ( auto it = bullets->be

(原)使用vectot的.end()报错:iterators incompatible

转载请注明出处: http://www.cnblogs.com/darkknightzh/p/5070672.html 参考网址: http://blog.csdn.net/yxnyxnyxnyxnyxn/article/details/17610899 之前用vector一直没有问题,前几天遍历时, for (auto it = var.sta.begin(); it != var.sta.end();) 运行时直接报:iterators incompatible 网上搜了一下,很多是说使用e

vector的坑——C++primer练习6.33总结

说来惭愧,一道简单的对vector递归的题目写了一个多小时,最后还是请教了大神才改出来. 首先贴上原代码: void return_vector(vector<int>::iterator,vector<int>); int main() { int n, temp; vector<int> symbol{}; cin >> n; for (int i = 0; i < n; ++i) { cin >> temp; symbol.push_

支线任务5

题目:The Skyline Problem A city's skyline is the outer contour of the silhouette formed by all the buildings in that city when viewed from a distance. Now suppose you are given the locations and height of all the buildings as shown on a cityscape photo

算法导论第六章优先队列(二)

优先队列可以说是堆的一个非常重要的应用,和堆对应,优先队列也分最小优先队列和最大优先队列. 优先队列是一种用来维护由一组元素构成的集合S的数据结构,其中每一个元素都有一个关键字(key),关键字赋予了一个元素的优先级,故名为优先队列.之所以用堆来实现优先队列,我想最大的原因是堆很容易对元素按关键字进行排序. 优先队列的应用: 最大优先队列:其中最为典型的就是“共享计算机系统的作业调度”,通过记录各个作业的优先级,来调度一个作业的执行.删除和插入等操作. 最小优先队列:可以被用于“基于事件驱动的模

STL使用迭代器逆向删除

网上有很多这种例子: void erase(vector<int> &v) { for(vector<int>::reverse_iterator ri=v.rbegin();ri!=v.rend();) { if(*ri % 2 == 0) { cout << "Erasing " << *ri << endl; v.erase((++ri).base()); //用base()函数将逆向iterator转换为正向的

STL vector方法总结(二)Iterators(35)

这里是vector的所有构造方法,成员方法的一些总结,具体的可以详看后面的链接. public member function <vector> std::vector::begin C++98 C++11 iterator begin(); const_iterator begin() const; 该方法返回一个指向该vector中第一个元素的iterator. 需要注意的是,和front()方法不同,front是返回第一个元素的引用,而begin返回的是一个指向第一个元素的随机访问迭代器

Vector容器 和 iteration 迭代器

vector容器 vector是同一种类型的对象的集合,每个对象都有一个对应的整数索引值.和string对象一样,标准库负责管理存储元素的相关内存.我们把vector称为容器,是因为它可以包含其他对象.一个容器中的所有对象都必须是同一种类型的. 使用vector之前,必须包含相应的头文件.#include <vector> using std::vector; vector是一个类模板(class template).模板允许程序员编写单个类或函数定义,这个类和函数定义可用于不同的数据类型上.