数据多了用对象存,对象多了用集合存
1,数组是固定长度的,集合是可变长度的
2,数组创建时就已经确定其存储的类型了,而集合可以存object(不同类型的对象)
Collection 下面常用的有List和Set
List常用的有ArrayList LinkedList Vector
Set常用的有HashSet TreeSet
为什么会出现这么多的容器的呢?
因为没一个容器对数据的存储方式都有不同,这个存储方式称之为:数据结构(数据在内存中存放的形式)
集合和数组的引用变量中存放的都是对象地址.
什么是迭代器?迭代器就是取出元素的方式
毕老师比喻:
娃娃机就是集合,就是容器,里面都有夹子(每个集合中的内部类),他们会实现迭代器接口(抽象夹子的作用形成的接口).
每个娃娃机(容器)的夹子(迭代器接口的实现类)可能具体形式不一样(hasNext(),next(),remove()其中的方法实现可能不一样),
但是作用和功能都是一样的(hasNext(),next(),remove()判断和取出和移除),
而且外界都是使用操纵杆(iterator()方法返回子类对象)操作夹子取出元素.
for(Iterator it:al.iterator();it.hasNext();){
it.next();
}
for循环比while循环好在 Iterator it:al.iterator() 此时是局部的,for循环结束后就没了,而while循环需要等待回收站自动回收
List 可重复 有顺序 其中有索引
因为有索引,所以它可以用for循环遍历获得其中各个元素
列表迭代器 ListIterator
Set 不可重复 无序