迭代器

迭代器:

是一种设计模式,提供了一种方法,来对集合、容器进行遍历的方法
不需要关注底层数据结构的是据类型,来达到底层和上层遍历的目的

iterator迭代器方法介绍:

boblean hasNext():判断集合是否还存在元素, true:还存在 false:不存在

E next(): 返回当前数据类型

void remove():删除元素

使用上:hasNext和next是轮循出现的 hasNext和remove也是轮循出现的

要自定义迭代器类

类要具有iterator方法需要实现iterator接口

自定义迭代器需要实现iterator接口

并发异常问题:ConcurrentModificationException

原因:集合本身修改会引起modCount版本号修改,而迭代器本身版本号副本并未改变,因此会抛出异常

ArrayList和数组的区别:

(1)初始化大小:ArrayList可以不指定大小,数组必须指定大小
(2)存储数据类型:ArrayList只能存储引用类型
数组可以存储引用类型和基本类型
Array是数组,申明时就要初始化并且确定大小,长度不可改变,只能存储同一类型的数据
ArrayList是集合,需要先申明,然后再添加数据,长度是可以根据类型而改变的,
可以存储不同类型的数据,存储基本类型数据的时候要使用基本数据的包装类

iterator和ListIterator的区别和联系

区别:
1.ListIterator有add()方法,可以向List中添加对象,而Iterator不能;
2.ListIterator和Iterator都有hasNext()和next()方法,可以实现顺序向后遍历,但是ListIterator有hasPrevious()和previous()方法,可以实现逆向(顺序向前)遍历,Iterator不可以;
3.ListIterator可以定位当前的索引位置,nextIndex()和previousIndex()可以实现,Iterator没有此功能;
4.都可实现删除对象,但是ListIterator可以实现对象的修改,set()方法可以实现,Iterator仅能遍历,不能修改;

fair- fast 机制 ==》 快速失败机制

是collection中的一种错误机制,当多个线程对同一个集合的内容进行操作时,就可能会产生快速失败机制,会抛出ConcurrentModificationExecption异常能够防止多个进程同时修改同一个容器的内容

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值