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

      STL有三大核心部分:容器(Container)、算法(Algorithms)、迭代器(Iterator),容器适配器(container adaptor),函数对象(functor),除此以外还有STL其余标准组件,若是你使用容器不当,就会发生list  iterators  incompatible/vector iterators  incompatible 的错误,报错如图:c++

若是你trace代码,你能够看到以下代码:算法

bool operator==(const _Myiter& _Right) const
		{	// test for iterator equality
 #if _ITERATOR_DEBUG_LEVEL == 2
		if (this->_Getcont() == 0
			|| this->_Getcont() != _Right._Getcont())
			{	// report error
			_DEBUG_ERROR("list iterators incompatible");
			_SCL_SECURE_INVALID_ARGUMENT;
			}

 #elif _ITERATOR_DEBUG_LEVEL == 1
		_SCL_SECURE_VALIDATE(this->_Getcont() != 0
			&& this->_Getcont() == _Right._Getcont());
 #endif /* _ITERATOR_DEBUG_LEVEL */

		return (this->_Ptr == _Right._Ptr);
		}

	bool operator!=(const _Myiter& _Right) const
		{	// test for iterator inequality
		return (!(*this == _Right));
		}
	};

 这个错误是“list iterators incompatible”,提示向量与迭代器不兼容,可是这很明显是不可能的(除非你故意这么作);若是你对容器操做不熟悉,你可能犯一下错误:编程

One:类型不匹配,例如用int型的向量迭代器与char型的向量迭代器进行比对操做。犯此错误的概率不大,除非你的本身的程序架构都不熟悉,而且不知道本身在作什么;架构

Two: 比对时容器的结构发生变化,例如:函数

for (vector<int>::iterator i= vector.begin();  i != vector.end();   i++) this

spa

 vector.erase(i); code

} 对象

在erase操做后,没有将循环变量i指向修改后的向量迭代器,就继续循环,再与end()比较时断言出现。 解决方法是将“vector.erase(i);”替换为“i = vector.erase(i);”,这是由于STL里的全部容器类中的erase实现都会返回一个迭代器,这个迭代器指向了“当前删除元素的后继元素,或是end()”。it

Three:将容器以参数的的形式,而且与实参相比较,应该用实参的引用,由于对于引用时实参的一个别名,是同一个变量,而已参数传递的是实参的副本,详情能够参考(c++ primer 关于引用章节,能够深刻体会),这样作也能够提升程序的效率,减小了构造/析构函数的开销,这也是一种良好的编程习惯,曾经本身在此吃过苦头!




相关文章
相关标签/搜索