Java集合系列

前言

“衣带渐宽终不悔,为伊消得人憔悴”    —柳永《蝶恋花·伫倚危楼风细细》

在这里插入图片描述

1 Collection集合

1.1 数组和集合的区别

1. 相同点

       都是容器,可以存储多个数据

2. 不同点

  • 数组的长度是不可变的,集合的长度是可变的

  • 数组可以存基本数据类型和引用数据类型

  • 集合只能存引用数据类型,如果要存基本数据类型,需要存对应的包装类

1.2 集合类体系结构

在这里插入图片描述

1.3 泛型

泛型的定义格式

<类型>: 指定一种类型的格式.尖括号里面可以任意书写,例如: <T> <T,V>

1.4 Collection 集合概述和使用

1. 创建Collection集合的对象

// 1.多态的方式
Collection<String> collection = new ArrayList();

// 2.具体的实现类
ArrayList<String> list = new ArrayList<>();

2. Collection集合常用方法

方法名说明
boolean add(E e)添加元素
boolean remove(Object o)从集合中移除指定的元素
void clear()清空集合中的元素
boolean contains(Object o)判断集合中是否存在指定的元素
boolean isEmpty()判断集合是否为空
int size()集合的长度,也就是集合中元素的个数

1.5 Collection集合的遍历

1.5.1 迭代器遍历

1.迭代器介绍

  • 迭代器,集合的专用遍历方式
  • Iterator iterator(): 返回此集合中元素的迭代器,通过集合对象的iterator()方法得到

2.Iterator中的常用方法

  • boolean hasNext(): 判断当前位置是否有元素可以被取出
  • E next(): 获取当前位置的元素,将迭代器对象移向下一个索引位置

3.Collection集合的遍历

package com.syh;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;

public class Esther {
    public static void main(String[] args) {
        // 1.创建集合对象
        Collection<String> c = new ArrayList<>();

        // 2.添加元素
        c.add("a");
        c.add("b");
        c.add("c");

        // 3.得到集合的iterator()方法
        Iterator<String> it = c.iterator();

        // 4.遍历集合
        while (it.hasNext()) {
            String s = it.next();
            System.out.println(s);
        }
    }
}
1.5.2 增强for

1. 增强for格式

for(集合/数组中元素的数据类型 变量名 :  集合/数组名) {
}

2. 代码示例

package com.syh;

import java.util.ArrayList;

public class Esther {
    public static void main(String[] args) {
        // 1.创建集合对象
        ArrayList<String> list = new ArrayList<>();

        // 2.往集合中添加元素
        list.add("a");
        list.add("b");
        list.add("c");
        list.add("d");

        // 3.遍历集合
        for (String str : list) {
            System.out.println(str);
        }
    }
}
1.5.3 lambda表达式

       利用forEach方法,再结合lambda表达式的方式进行遍历

package com.syh;

import java.util.ArrayList;
import java.util.Collection;

public class Esther {
    public static void main(String[] args) {

        // 1.创建集合对象并添加元素
        Collection<String> coll = new ArrayList<>();

        // 2.往集合中添加元素
        coll.add("zhangsan");
        coll.add("lisi");
        coll.add("wangwu");

        // 3.lambda表达式
        coll.forEach(s -> System.out.println(s));
    }
}

2 List集合

2.1 List集合的特点

  • 存取有序
  • 可以重复
  • 有索引

2.2 ArrayList集合的方法

方法名描述
void add(E element)插入元素到尾部
E remove(int index)删除指定索引处的元素
E set(int index,E element)修改指定索引处的元素
E get(int index)返回指定索引处的元素

示例代码

package com.syh;

import java.util.ArrayList;
import java.util.List;

public class Esther {
    public static void main(String[] args) {
        List<String> list = new ArrayList<>();
        list.add("aaa");
        list.add("bbb");
        list.add("ccc");

        add(list);
        remove(list);
        set(list);
        get(list);
    }

    private static void add(List<String> list) {
        // 1.在指定索引处添加元素
        list.add("ddd");
        System.out.println(list);
    }
    private static void remove(List<String> list) {
        // 2.删除指定索引处的元素
        String s = list.remove(3);
        System.out.println(list);
    }

    private static void set(List<String> list) {
        // 3.修改指定索引处的元素
        String result = list.set(2, "qqq");
        System.out.println(list);
    }
    private static void get(List<String> list) {
        // 4.获取指定索引处的元素
        String s = list.get(0);
        System.out.println(s);
    }
}

2.3 LinkedList集合的功能

方法名说明
public void addFirst(E e)在该列表开头插入指定的元素
public void addLast(E e)将指定的元素追加到此列表的末尾
public E getFirst()返回此列表中的第一个元素
public E getLast()返回此列表中的最后一个元素
public E removeFirst()从此列表中删除并返回第一个元素
public E removeLast()从此列表中删除并返回最后一个元素

示例代码

package com.syh;

import java.util.LinkedList;

public class Esther {
    public static void main(String[] args) {
        LinkedList<String> list = new LinkedList<>();
        list.add("aaa");
        list.add("bbb");
        list.add("ccc");

        addFirst(list);
        addList(list);
        getFirst(list);
        getLast(list);
        removeFirst(list);
        removeLast(list);
    }

    private static void addFirst(LinkedList<String> list) {
        // 1.在列表开头添加元素
        list.addFirst("111");
        System.out.println(list);
    }

    private static void addList(LinkedList<String> list) {
        // 2.在列表结尾添加元素
        list.addLast("222");
        System.out.println(list);
    }
    private static void getFirst(LinkedList<String> list) {
        // 3.获取列表开头的元素
        String first = list.getFirst();
        System.out.println(first);
    }
    private static void getLast(LinkedList<String> list) {
        // 4.获取列表结尾的元素
        String last = list.getLast();
        System.out.println(last);
    }
    private static void removeFirst(LinkedList<String> list) {
        // 5.删除列表开头的元素
        String first = list.removeFirst();
        System.out.println(list);
    }
    private static void removeLast(LinkedList<String> list) {
        // 6.删除列表结尾的元素
        String last = list.removeLast();
        System.out.println(list);
    }
}

3 Set集合

3.1 Set集合的特点

  • 不可以存储重复元素
  • 没有索引,不能使用普通for循环遍历

3.2 HashSet集合

1. HashSet集合概述

  • 底层数据结构是哈希表
  • 存取无序
  • 不可以存储重复元素
  • 没有索引,不能使用普通for循环遍历

2. 代码示例

package com.syh;

import java.util.HashSet;

public class Esther {
    public static void main(String[] args) {
        // 1.创建集合对象
        HashSet<String> set = new HashSet<String>();

        // 2.添加元素
        set.add("hello");
        set.add("world");
        set.add("java");
        
        set.add("world");

        // 3.遍历
        for (String s : set) {
            System.out.println(s);
        }
    }
}

3.3 TreeSet集合

1. TreeSet集合概述

  • 不可以存储重复元素
  • 没有索引
  • 根据其元素的自然排序进行排序

2. 代码示例

package com.syh;

import java.util.TreeSet;

public class Esther {
    public static void main(String[] args) {
        // 1.创建集合对象
        TreeSet<Integer> ts = new TreeSet<Integer>();

        // 2.添加元素
        ts.add(10);
        ts.add(40);
        ts.add(30);
        ts.add(50);
        ts.add(20);

        ts.add(30);

        // 3.遍历集合
        for(Integer i : ts) {
            System.out.println(i);
        }
    }
}

4 Map集合

4.1 Map集合概述

       Map集合是双列集合,包括键和值,例如:Map<K,V>

1. Map集合的特点

  • 双列集合,一个键对应一个值
  • 键不可以重复,值可以重复

2. 代码示例

package com.syh;

import java.util.HashMap;
import java.util.Map;

public class Esther {
        public static void main(String[] args) {
            // 1.创建集合对象
            Map<String,String> map = new HashMap<String,String>();

            // 2.添加元素
            map.put("001","李默然");
            map.put("002","徐则言");
            map.put("003","辰子希");
            map.put("003","云其墨");

            // 3输出集合对象
            System.out.println(map);
        }
    }

4.2 HashMap集合的方法

方法名说明
V put(K key,V value)添加元素
V remove(Object key)根据键删除键值对元素
void clear()移除所有的键值对元素
boolean containsKey(Object key)判断集合是否包含指定的键
boolean containsValue(Object value)判断集合是否包含指定的值
boolean isEmpty()判断集合是否为空
int size()集合的长度,也就是集合中键值对的个数

示例代码

package com.syh;

import java.util.HashMap;
import java.util.Map;

public class Esther {
    public static void main(String[] args) {
        // 1.创建集合对象
        Map<String, String> map = new HashMap<String, String>();

        // 2.添加元素
        map.put("001","云其墨");
        map.put("002","徐则言");
        map.put("003","辰子希");
        map.put("004","李默然");

        // 3.根据键删除键值对元素
        System.out.println(map.remove("004"));

        // 4.清空键值对元素
        map.clear();

        // 5.判断集合是否包含指定的键
        System.out.println(map.containsKey("001"));

        // 6.判断集合是否包含指定的值
        System.out.println(map.containsValue("李默然"));

        // 7.判断集合是否为空
        System.out.println(map.isEmpty());

        // 8.集合的长度,也就是集合中键值对的个数
        System.out.println(map.size());

        //输出集合对象
        System.out.println(map);
    }
}

4.3 HashMap集合的获取方法

方法名说明
V get(Object key)根据键获取值
Set keySet()获取所有键的集合
Collection values()获取所有值的集合
Set<Map.Entry<K,V>> entrySet()获取所有键值对对象的集合

示例代码

package com.syh;

import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;

public class Esther {
    public static void main(String[] args) {
        // 1.创建集合对象
        Map<String, String> map = new HashMap<String, String>();

        // 2.添加元素
        map.put("001", "云其墨");
        map.put("002", "徐则言");
        map.put("003", "辰子希");

        // 3.根据键获取值
        String value = map.get("001");
        System.out.println(value);

        // 4.获取所有键的集合
        Set<String> keySet = map.keySet();
        for (String key : keySet) {
            System.out.println(key);
        }

        // 5.获取所有值的集合
        Collection<String> values = map.values();
        for (String value1 : values) {
            System.out.println(value1);
        }

        // 6.获取所有键值对的集合
        System.out.println(map.entrySet());
    }
}

4.4 HashMap集合的遍历

  • 第一种根据键获取值
  • 第二种直接获取Map集合对象

代码实现

package com.syh;

import java.util.HashMap;
import java.util.Map;
import java.util.Set;

public class Esther {
    public static void main(String[] args) {
        // 1.创建集合对象
        Map<String, String> map = new HashMap<String, String>();

        // 2.添加元素
        map.put("001", "云其墨");
        map.put("002", "徐则言");
        map.put("003", "辰子希");
        map.put("004", "李默然");

        // 3.根据键获取值遍历
        Set<String> keySet = map.keySet();
        for (String key : keySet) {
            String value = map.get(key);
            System.out.println(key + "," + value);
        }

        // 4.获取所有键值对对象的集合遍历
        Set<Map.Entry<String, String>> entrySet = map.entrySet();
        for (Map.Entry<String, String> me : entrySet) {
            String key = me.getKey();
            String value = me.getValue();
            System.out.println(key + "," + value);
        }
    }
}

4.5 TreeMap集合

1. TreeMap集合概述

  • TreeMap底层是红黑树结构
  • 依赖自然排序或者比较器排序,对键进行排序
  • 如果键存储的是自定义对象,需要实现Comparable接口或者在创建TreeMap对象时候给出比较器排序规则

2. 代码示例

package com.syh;

import java.util.TreeMap;

public class Esther {
    public static void main(String[] args) {
        // 1.创建TreeMap集合对象
        TreeMap<String, String> tm = new TreeMap<>();

        // 2.添加元素
        tm.put("江苏省", "南京市");
        tm.put("广东省", "广州市");
        tm.put("浙江省", "杭州市");

        // 3.遍历集合
        tm.forEach((String key, String value) -> System.out.println(key + "---" + value));
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值