一、长度获取:
1.array length
2.字符串长度 length()
3.ArrayList长度 size()
二、集合的体系结构:
1.由于不同的数据结构(数据的组织,存储方式),所以Java为我们提供了不同的集合
但是不同的集合功能是相似的,不断向上提取,将共性抽取出来,这就是集合体系结构形成的原因
2.体系结构:
怎么学习?从最顶层开始学习,最顶层包含所有的共性
怎么使用?使用最底层,因为最底层就是具体的实现
Collection-->List-->ArrayList
三、Collection中的常用功能
1.Collection接口,不同集合存储数据的方式不同,Collection只能定义一些规范
2.boolean add(E e)//永远可以添加成功,ArrayList 允许重复
3.void clear()//清空集合
4.boolean contains(Object o)//是否包含某个元素
5.boolean isEmpty()//是否为空
6.boolean remove(Object o)// 删除元素
7.int size()
8.Object[] toArray():将集合转换成object数组
四、集合中可以存任意引用型对象
Iterator<E> iterator
List l = new ArrayList();
ListIterator it = l.ListIterator();//l为collection对象
while(it.hasNet()){
string s = (string)it.next();
if(s.equals("java")){
it.add("android");
}
}
迭代器是依赖于集合的,相当于集合的一个副本,当迭代器在操作的时候,如果发现和集合不一样,则抛出异常。就是说如果直接往集合中添加新的元素,迭代器发现集合与自身不同,就会抛出异常,这时候正确的做法应该是往迭代器中添加元素,然后迭代器再去更新集合。由于Iterator中没有添加元素的方法,所以用其子类ListIterator,这是一个接口。
五、使用集合存储自定义对象并遍历
由于集合可以存储任意类型的对象,就有可能在转换是出现类型转换异常,所以Java为了解决这个问题,给我们提供了一种机制,叫做泛型。
1.泛型:是一种广泛的类型,把明确数据类型的工作提前到了编译时期,借鉴了数组的特点。
2.泛型的好处:避免了类型转换错误到运行时期才发现的
3.foreach
(1)增强for循环,一般用于遍历集合或者数组
(2)格式:
for(元素的类型变量:集合或者数组对象){
可以直接使用变量;
}
for(Object obj : c){
System.out.println(obj);
}
注意:在集合中for循环中不能修改集合,否则会出现并发修改异常。增强for底层是迭代器
六、常见数据结构:
1.数组的特点:
(1)数组的长度一旦定义则不能改变
(2)数组中的元素都有 整数索引
(3)数组只能存储同意类型的元素
(4)数组既可以存储基本数据类型,也可以存储引用类型
想要在元素3后面添加一个新的元素?
创建一个新的数组,长度是原先数组长度+1
查找快,增删慢
2.栈:先进后出
3.队列:先进先出
七、List
1.特点:
有序的(存储和读取的顺序是一致的)
有整数索引
允许重复
2.List的特有功能:
void add(int index,E element) :在指定索引位置添加指定元素
E get(int index):根据索引返回元素
E remove(int index):删除指定元素并返回
E set(int index,E element):将指定索引位置的元素替换为指定元素,并将原先的元素返回
3.List的常用子类:
(1)ArrayList:
底层是数组节后,查询快,增删慢
(2)LinkedList:
底层结构是链表,查询慢,增删快
void addFirst(E e)
void addLast(E e)
E getFirst()
E getLast()
E removeFirst()
E removeLast()
使用这些方法模拟栈和队列
(3)如何选择使用不同的集合?
查询多、增删少,使用ArrayList
查询少、增删多,使用LinkedList
如果不知道使用什么,使用ArrayList