资讯 小学 初中 高中 语言 会计职称 学历提升 法考 计算机考试 医护考试 建工考试 教育百科
栏目分类:
子分类:
返回
空麓网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
空麓网 > 计算机考试 > 软件开发 > 后端开发 > Java

list迭代器失效问题

Java 更新时间: 发布时间: 计算机考试归档 最新发布

list迭代器失效问题

与数组相比,list的迭代器

    数组是一段连续的空间,迭代器是内置类型的原生指针,迭代器++或者--就可以控制迭代器的移动,插入时可能会发生扩容,而一旦扩容,迭代器就会失效。(迭代器it依然指向之前空间的位置,但那片空间已经被释放,所以迭代器变成野指针)。

     list是一个链表结构,它是有一个个单独的结点组成,插入或者删除不会出现空间开辟放大的问题。迭代器it依然指向那个位置,迭代器不会失效,但会返回插入结点的迭代器。但erase()会使it的迭代器失效,毕竟那个结点都被释放了。因此在删除数据结点时,返回下一个结点的迭代器

        iterator insert(iterator pos, const T& x)
		{
			Node* newnode = new Node(x);
			Node* cur = pos._node;
			Node* prev = cur->_prev;
			prev->_next = newnode;
			newnode->_prev = prev;
			newnode->_next = cur;
			cur->_prev = newnode;

			return iterator(newnode);
		}
		iterator erase(iterator pos)
		{
			assert(pos != end());
			Node* cur = pos->_node;
			Node* prev = cur->_prev;
			Node* next = cur->_next;
			prev->_next = next;
			next->_prev = prev;
			delete cur;
			return iterator(next);
		}

 

转载请注明:文章转载自 http://www.konglu.com/
本文地址:http://www.konglu.com/it/1025028.html
免责声明:

我们致力于保护作者版权,注重分享,被刊用文章【list迭代器失效问题】因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理,本文部分文字与图片资源来自于网络,转载此文是出于传递更多信息之目的,若有来源标注错误或侵犯了您的合法权益,请立即通知我们,情况属实,我们会第一时间予以删除,并同时向您表示歉意,谢谢!

我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2023 成都空麓科技有限公司

ICP备案号:蜀ICP备2023000828号-2