错误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()等其他几乎一切操作,但是这个向量缺唯独不能执行遍历者一种操作.