Iterator为什么不能对容器的进行添加或修改操作(可以删除)

为什么java中迭代过程中不能加元素 
有这样的情况: 
Java代码   收藏代码
  1. List<Integer> list = new ArrayList<Integer>();  
  2. list.add(0);  
  3. Iterator<Integer> iterator = list.iterator();  
  4. while(iterator.hasNext()) {  
  5.     int i = iterator.next();  
  6.     if(i = 0) {  
  7.           list.add(1);  
  8.           list.remove(0);  
  9.      }  
  10. }  
  11. ...  

此时系统编译执行会抛出异常!!!为什么呢? 
逻辑上讲,迭代时可以添加元素,但是一旦开放这个功能,很有可能造成很多意想不到的情况。 
比如你在迭代一个ArrayList,迭代器的工作方式是依次返回给你第0个元素,第1个元素,等等,假设当你迭代到第5个元素的时候,你突然在ArrayList的头部插入了一个元素,使得你所有的元素都往后移动,于是你当前访问的第5个元素就会被重复访问。 
java认为在迭代过程中,容器应当保持不变。因此,java容器中通常保留了一个域称为modCount,每次你对容器修改,这个值就会加1。当你调用iterator方法时,返回的迭代器会记住当前的modCount,随后迭代过程中会检查这个值,一旦发现这个值发生变化,就说明你对容器做了修改,就会抛异常。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 C++ 中,迭代器(iterator)是一个对象,它能够遍历容器(如 vector、list、map 等)中的元素,类似于指针。通过迭代器,我们可以在不知道容器内部实现细节的情况下,访问容器中的元素。具体来说,迭代器提供了以下功能: 1. 遍历容器中的元素:使用迭代器可以轻松地遍历容器中的元素,从而进行查询、修改操作。 2. 访问容器中的元素:通过迭代器,可以访问容器中的元素。 3. 定位元素位置:迭代器可以用于定位容器中特定元素的位置,从而进行删除、插入等操作。 4. 提供算法支持:STL 中的很多算法(如 sort、find 等)都是通过迭代器实现的。 下面是一个使用迭代器遍历 vector 容器的示例代码: ```c++ #include <iostream> #include <vector> using namespace std; int main() { vector<int> vec; // 向 vector 容器添加元素 vec.push_back(10); vec.push_back(20); vec.push_back(30); // 使用迭代器遍历 vector 容器中的元素 vector<int>::iterator iter; for (iter = vec.begin(); iter != vec.end(); iter++) { cout << *iter << " "; } return 0; } ``` 上述代码中,我们首先定义了一个 int 类型的 vector 容器 vec,然后使用 push_back() 函数向容器添加了三个元素。接着,我们使用迭代器 iter 遍历容器中的元素,并打印输出。运行代码,输出结果如下: ``` 10 20 30 ``` 可以看到,使用迭代器可以轻松地遍历 vector 容器中的元素,从而进行查询、修改操作

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值