微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

迭代器报“vector iterators incompatible”错的几种可能

错误1:

vector<int > v1;

for (vector<int>::iterator it= v1.begin(); it != v1.end();  it++) // 这里报错
{
	if(*it==8)
	{
		v1.erase(it);
	}
}

解决方法

vector<int > v1;

for(vector<int>::iterator it = v1.begin(); it!= v1.end();)
{
	if (it == 8)
	{
		it = v1.erase(it);
	}
	else
	{
		it++;
	}
}



错误2: 类型不匹配,例如用int型的向量迭代器与char型的向量迭代器进行比对操作。


错误3:结构体里面有vector等成员时,不要用memset清零 实例如下:

....
typdef struct _STRUCT
{
    ....
    vector<INFO> vecInfo;
}STRUCT;

STRUCT stcStruct;

....

for (vector<INFO>::iterator i= stcStruct.vecInfo.begin(); i != stcStruct.vecInfo.end(); i++) // 这里报错
{
   .... www.2cto.com
}
尝试跟进库代码,在向量类的不等号重载中跟到了以下代码中,而后发现玄机

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;
    }
}
我们在跟进_Getcont(),_Getcont()代码如下:

const _Container_base12 *_Getcont() const
{   // get owning container
    return (_Myproxy == 0 ? 0 : _Myproxy->_Mycont);
}
在这里我发现我那段代码中的_Myproxy是为0的,也就是说我们的类型应该不存在问题,而是向量的“链条”断掉了。
从库的跟踪中我发现向量是使用名称为“_Myproxy”、“_Mynextiter”这两个指针来寻找与之相邻的值的,在我们定义一个向量时,它便初始化一个“_Myproxy”,而我的代码却在类的构造函数中对定义的结构体执行了一个清零的操作:ZeroMemory(&m_stcStruct,sizeof(STRUCT));
从而导致了向量中的“_Myproxy”丢失,虽然仍可以对其进行push_back()等其他几乎一切操作,但是这个向量缺唯独不能执行遍历者一种操作.





版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐