集合-1

1.集合的概念

  1. 集合就是用于存储多个数据的容器。相对于具有相同功能的数组来说,集合的长度可变会更加灵活方便。Java中提供了使用不同数据结构存储数据的不同集合类,他们有各自不同的特点,并且在类中提供了很多常用了方法,便于我们使用。

2.集合体系结构

  1. 集合主要有两个顶层接口,CollectionMap。<br />![集合体系图.png](https://cdn.nlark.com/yuque/0/2022/png/25966321/1650013961855-06e02dab-f02f-4954-a3c5-32cad48969c8.png#clientId=u0e50ed41-f3d2-4&crop=0&crop=0&crop=1&crop=1&from=drop&id=u2cde388a&margin=%5Bobject%20Object%5D&name=%E9%9B%86%E5%90%88%E4%BD%93%E7%B3%BB%E5%9B%BE.png&originHeight=495&originWidth=1576&originalType=binary&ratio=1&rotation=0&showTitle=false&size=42077&status=done&style=none&taskId=u306562b3-8bc2-48a3-b015-58e6b569f2f&title=)

3. 常用list集合

3.1 list集合的特点

  1. List接口下的集合都会有以下特点:
  • 有索引
  • 可以存储重复元素
  • 元素存入的顺序和实际存储的顺序相同

3.2 ArrayList

3.2.1 创建对象

  1. ArrayList list = new ArrayList<>();//不限定集合中存放元素的数据类型
  2. ArrayList<集合元素的数据类型> list2 = new ArrayList<>();//限定集合中存放元素的数据类型

3.2.2 常用方法

  1. boolean add(E e) //添加元素,直接添加到集合的末尾 返回值代表是否添加成功
  2. void add(int index, E element) //往指定索引位置添加元素
  3. boolean remove(Object o)// 删除元素
  4. E remove(int index) //删除指定索引位置的元素,返回值是被删除的元素
  5. E set(int index, E element) //修改指定索引位置的元素 返回值为修改之前的元素值
  6. E get(int index) //获取指定索引位置的元素 返回值为对应的元素
  7. int size() //获取集合中元素的个数
  8. boolean contains(Object o) //判断集合中是否存在某个元素 ,返回值代表是否存在

我们平时对集合用的最多的是add,remove,get,set,size这几个方法。

3.2.3 遍历

1.使用索引遍历

  1. public static void main(String[] args) {
  2. ArrayList<String> list = new ArrayList<>();
  3. list.add("三");
  4. list.add("更");
  5. list.add("草");
  6. list.add("堂");
  7. for (int i = 0; i < list.size(); i++) {
  8. System.out.println(list.get(i));
  9. }
  10. }

2.使用迭代器遍历

  1. public static void main(String[] args) {
  2. ArrayList<String> list = new ArrayList<>();
  3. list.add("三");
  4. list.add("更");
  5. list.add("草");
  6. list.add("堂");
  7. Iterator<String> it = list.iterator();
  8. while (it.hasNext()){
  9. String s = it.next();
  10. System.out.println(s);
  11. }
  12. }

注意:为了避免并发修改异常(ConcurrentModificationException)的出现。避免在使用迭代器遍历的过程中对集合进行操作。

3.使用foreach遍历

  1. foreachjava提供的一个语法糖。可以让我们更方便的遍历集合或数组。

格式如下:

  1. for(元素数据类型 变量名 : 遍历的集合或者数组){
  2. //遍历的时候会把遍历到的元素赋值给我们上面定义的变量
  3. }

例如:

  1. public static void main(String[] args) {
  2. ArrayList<String> list = new ArrayList<>();
  3. list.add("三");
  4. list.add("更");
  5. list.add("草");
  6. list.add("堂");
  7. for (String s : list) {
  8. System.out.println(s);
  9. }
  10. }
  1. String[] arr = {"三","更","草","堂"};
  2. for(String s : arr){
  3. System.out.println(s);
  4. }

4.转换为数组遍历

  1. public static void main(String[] args) {
  2. ArrayList<String> list = new ArrayList<>();
  3. list.add("三");
  4. list.add("更");
  5. list.add("草");
  6. list.add("堂");
  7. //把list集合转换为数组 参数列表 返回值类型 []
  8. // Object[] objects = list.toArray();
  9. //遍历数组
  10. // for (int i = 0; i < objects.length; i++) {
  11. // System.out.println(objects[i]);
  12. // }
  13. // public <T> T[] toArray(T[] a)
  14. String[] strings = list.toArray(new String[0]);
  15. for (String string : strings) {
  16. System.out.println(string);
  17. }
  18. }

3.3 LinkedList

3.3.1 创建对象

  1. LinkedList list = new LinkedList<>();//不限定集合中存放元素的数据类型
  2. LinkedList<集合元素的数据类型> list2 = new LinkedList<>();//限定集合中存放元素的数据类型

3.3.2 常用方法

  1. boolean add(E e) //添加元素,直接添加到集合的末尾 返回值代表是否添加成功
  2. void add(int index, E element) //往指定索引位置添加元素
  3. boolean remove(Object o)// 删除元素
  4. E remove(int index) //删除指定索引位置的元素,返回值是被删除的元素
  5. E set(int index, E element) //修改指定索引位置的元素 返回值为修改之前的元素值
  6. E get(int index) //获取指定索引位置的元素 返回值为对应的元素
  7. int size() //获取集合中元素的个数
  8. boolean contains(Object o) //判断集合中是否存在某个元素 ,返回值代表是否存在
  1. public static void main(String[] args) {
  2. LinkedList<String> list = new LinkedList<>();
  3. //添加元素
  4. list.add("更");
  5. list.add(0,"三");
  6. //删除元素
  7. list.remove("三");
  8. //修改元素
  9. list.set(0,"三更草堂");
  10. //获取元素
  11. String s = list.get(0);
  12. //获取集合大小
  13. int size = list.size();
  14. //判断元素是否存在
  15. boolean flag = list.contains("三更草堂");
  16. }

我们发现上面这些方法其实和ArrayList中的常用方法都是相同的。因为LinkedList和ArrayList都是List接口的实现类,上面的很多方法都是他们共同的接口中定义的方法,所以都会有。

下面是LinkedList的一些特有方法:

  1. void addFirst(E e) //把元素添加到集合的最前面
  2. void addLast(E e) //把元素添加到集合的最后面
  3. E removeFirst() //删除集合最前面的一个元素,返回值代表被删除的元素
  4. E removeLast() //删除集合最后面的一个元素,返回值代表被删除的元素
  1. public static void main(String[] args) {
  2. LinkedList<String> list = new LinkedList<>();
  3. list.add("三");
  4. list.add("更");
  5. list.add("草");
  6. list.add("堂");
  7. list.addFirst("[");
  8. list.addLast("]");
  9. String s = list.removeFirst();
  10. System.out.println(s);
  11. String s1 = list.removeLast();
  12. System.out.println(s1);
  13. }

3.3.3 遍历

  1. ArrayList
  1. public static void main(String[] args) {
  2. LinkedList<String> list = new LinkedList<>();
  3. list.add("三");
  4. list.add("更");
  5. list.add("草");
  6. list.add("堂");
  7. //遍历集合
  8. //for循环遍历
  9. // for (int i = 0; i < list.size(); i++) {
  10. // System.out.println(list.get(i));
  11. // }
  12. //迭代器
  13. // Iterator<String> it = list.iterator();
  14. // while (it.hasNext()){
  15. // String s = it.next();
  16. // System.out.println(s);
  17. // }
  18. //foreach
  19. // for(String s : list){
  20. // System.out.println(s);
  21. // }
  22. //转换为数组遍历
  23. String[] strings = list.toArray(new String[0]);
  24. for (int i = 0; i < strings.length; i++) {
  25. System.out.println(strings[i]);
  26. }
  27. }

3.4 ArrayList和LinkedList的区别

  1. 都是实现了List接口,不同点是底层存储数据的数据结构不同。ArrayList底层是用数组来存储,而LinkedList是链表。所以各自的特点也和数据结构的特点一样。
  2. **ArrayList 查找快,增删慢**
  3. **LinkedList: 增删快,查找慢**