【深入探究Java集合框架】从List到Map的完整指南

简介: 【深入探究Java集合框架】从List到Map的完整指南


🌟 Java集合框架

Java集合框架是Java编程语言提供的一组类和接口,用于表示集合,并提供了相关的操作和算法。在Java集合框架中,集合分为三种类型:ListSetMap。其中,List是有序的集合,允许重复元素;Set是无序且不允许重复元素的集合;而Map是一种映射关系,它将一个键与一个值相关联。这些集合提供了非常多的操作,比如添加、删除、查找、排序等。

🍊 Collection

Java集合框架中的根接口是Collection,它提供了基本的集合操作。在Collection接口中有两个子接口:ListSet

🎉 List

List接口是有序的集合,允许重复元素。List接口有三个主要的实现类:ArrayListVectorLinkedList。其中,ArrayList底层是一个数组,使用空间较少,线程不安全,因此性能较高。默认情况下,ArrayList的初始容量为10,当添加元素时,如果当前容量不足,则会进行扩容,扩容为原来的1.5倍。Vector是一个线程安全的List实现,它的底层也是一个数组,但是比ArrayList慢。LinkedList底层是双向链表,因此添加和删除元素的性能非常高,但是查找元素的性能较低。

示例代码如下:

import java.util.List;
import java.util.ArrayList;
import java.util.Vector;
import java.util.LinkedList;
public class ListExample {
    public static void main(String[] args) {
        // ArrayList示例
        List<String> arrayList = new ArrayList<>();
        arrayList.add("a");
        arrayList.add("b");
        arrayList.add("c");
        arrayList.add("a"); // 允许重复元素
        System.out.println("ArrayList示例:" + arrayList);
        // Vector示例
        List<String> vector = new Vector<>();
        vector.add("d");
        vector.add("e");
        vector.add("f");
        System.out.println("Vector示例:" + vector);
        // LinkedList示例
        List<String> linkedList = new LinkedList<>();
        linkedList.add("g");
        linkedList.add("h");
        linkedList.add("i");
        linkedList.add("g"); // 允许重复元素
        System.out.println("LinkedList示例:" + linkedList);
    }
}

🎉 Set

Set接口是无序并且不允许重复元素的集合。Set接口有三个主要的实现类:HashSetLinkedHashSetTreeSet。其中,HashSet底层实现是基于HashMap,使用哈希表来存储元素。当向HashSet中添加元素时,会根据元素的hashCode值来计算存储位置,如果该位置已经有元素,则将其链接在链表的末尾;如果链表长度达到8,则将链表转换为红黑树,以提高查找效率。LinkedHashSetHashSet的子类,底层实现也是基于HashMap,但是额外维护了一个链表,用于维护元素的插入顺序。TreeSet底层使用红黑树来存储元素,因此可以保证元素的有序性,并且提供了一些基于排序的操作。

示例代码如下:

import java.util.HashSet;
import java.util.LinkedHashSet;
import java.util.TreeSet;
public class SetExample {
    public static void main(String[] args) {
        // 创建一个HashSet集合
        HashSet<String> hashSet = new HashSet<>();
        // 添加元素到HashSet中
        hashSet.add("apple");
        hashSet.add("banana");
        hashSet.add("orange");
        hashSet.add("watermelon");
        hashSet.add("grape");
        hashSet.add("pineapple");
        // 遍历HashSet集合中所有元素
        for (String fruit : hashSet) {
            System.out.println(fruit);
        }
        // 创建一个LinkedHashSet集合
        LinkedHashSet<String> linkedHashSet = new LinkedHashSet<>();
        // 添加元素到LinkedHashSet中
        linkedHashSet.add("apple");
        linkedHashSet.add("banana");
        linkedHashSet.add("orange");
        linkedHashSet.add("watermelon");
        linkedHashSet.add("grape");
        linkedHashSet.add("pineapple");
        // 遍历LinkedHashSet集合中所有元素
        for (String fruit : linkedHashSet) {
            System.out.println(fruit);
        }
        // 创建一个TreeSet集合
        TreeSet<String> treeSet = new TreeSet<>();
        // 添加元素到TreeSet中
        treeSet.add("apple");
        treeSet.add("banana");
        treeSet.add("orange");
        treeSet.add("watermelon");
        treeSet.add("grape");
        treeSet.add("pineapple");
        // 遍历TreeSet集合中所有元素
        for (String fruit : treeSet) {
            System.out.println(fruit);
        }
    }
}

🎉 Map

Map是一种映射关系,它将一个键与一个值相关联。Map接口中的键是无序、不可重复的,值是无序但可重复的。Map接口有四个主要的实现类:HashMapLinkedHashMapTreeMapHashTable。其中,HashMap底层实现是基于哈希表,它使用键的hashCode值来计算存储位置,并使用链表(JDK1.8之后,链表长度达到8时会自动转化为红黑树)来解决哈希冲突。LinkedHashMapHashMap的子类,它维护了一个双向链表来维护元素的插入顺序。TreeMap底层使用红黑树来存储元素,根据键的自然排序或指定的比较器来排序键。HashTable是一个线程安全的Map实现,它的底层实现与HashMap相似,但不允许键或值为空,且操作都是同步的。

示例代码如下:

import java.util.*;
public class MapExamples {
    public static void main(String[] args) {
        // 创建HashMap示例
        Map<String, Integer> hashMap = new HashMap<>();
        hashMap.put("Alice", 25);
        hashMap.put("Bob", 30);
        hashMap.put("Charlie", 35);
        System.out.println("HashMap: " + hashMap);
        // 创建LinkedHashMap示例
        Map<String, Integer> linkedHashMap = new LinkedHashMap<>();
        linkedHashMap.put("Alice", 25);
        linkedHashMap.put("Bob", 30);
        linkedHashMap.put("Charlie", 35);
        System.out.println("LinkedHashMap: " + linkedHashMap);
        // 创建TreeMap示例
        Map<String, Integer> treeMap = new TreeMap<>();
        treeMap.put("Alice", 25);
        treeMap.put("Bob", 30);
        treeMap.put("Charlie", 35);
        System.out.println("TreeMap: " + treeMap);
        // 创建HashTable示例
        Hashtable<String, Integer> hashTable = new Hashtable<>();
        hashTable.put("Alice", 25);
        hashTable.put("Bob", 30);
        hashTable.put("Charlie", 35);
        System.out.println("HashTable: " + hashTable);
    }
}

🍊 集合的选择

在Java集合框架中,集合的选择应该根据集合的特点和使用场景进行选择。例如,如果需要有序并且允许重复元素的集合,则应该选择List接口;如果需要无序并且不允许重复元素的集合,则应该选择Set接口;如果需要维护映射关系,则应该选择Map接口。但是,具体的实现类的选择应该根据集合的性能需求和使用场景进行选择。例如,如果需要高效的随机访问和修改元素,则应该选择ArrayList;如果需要高效的添加和删除元素,则应该选择LinkedList。如果需要维护元素的插入顺序,则应该选择LinkedHashSetLinkedHashMap。如果需要元素的自然排序或者指定的比较器进行排序,则应该选择TreeSetTreeMap。如果需要线程安全,则应该选择VectorHashTable

Java代码示例:

🎉 1. 有序并允许重复元素的集合 List

List<String> list=new ArrayList<String>();
list.add("Hello");
list.add("World");
list.add("Java");
System.out.println(list);

🎉 2. 无序并且不允许重复元素的集合 Set

Set<String> set=new HashSet<String>();
set.add("Hello");
set.add("World");
set.add("Java");
System.out.println(set);

🎉 3. 维护映射关系的集合 Map

Map<String,Integer> map=new HashMap<String,Integer>();
map.put("Hello",1);
map.put("World",2);
map.put("Java",3);
System.out.println(map);

🎉 4. 高效的随机访问和修改元素 ArrayList

List<String> list=new ArrayList<String>();
list.add("Hello");
list.add("World");
list.add("Java");
System.out.println(list.get(1));
list.set(1,"Python");
System.out.println(list);

🎉 5. 高效的添加和删除元素 LinkedList

List<String> list=new LinkedList<String>();
list.add("Hello");
list.add("World");
list.add("Java");
System.out.println(list);
list.addFirst("Python");
list.removeLast();
System.out.println(list);

🎉 6. 维护元素的插入顺序 LinkedHashSet

Set<String> set=new LinkedHashSet<String>();
set.add("Hello");
set.add("World");
set.add("Java");
System.out.println(set);

🎉 7. 元素的自然排序或者指定的比较器进行排序 TreeSet

Set<String> set=new TreeSet<String>();
set.add("Hello");
set.add("World");
set.add("Java");
System.out.println(set);

🎉 8. 线程安全 Vector

List<String> list=new Vector<String>();
list.add("Hello");
list.add("World");
list.add("Java");
System.out.println(list);

🎉 9. 线程安全 HashTable

Map<String,Integer> map=new Hashtable<String,Integer>();
map.put("Hello",1);
map.put("World",2);
map.put("Java",3);
System.out.println(map);


相关文章
|
5天前
|
存储 安全 Java
Java 集合框架中的老炮与新秀:HashTable 和 HashMap 谁更胜一筹?
嗨,大家好,我是技术伙伴小米。今天通过讲故事的方式,详细介绍 Java 中 HashMap 和 HashTable 的区别。从版本、线程安全、null 值支持、性能及迭代器行为等方面对比,帮助你轻松应对面试中的经典问题。HashMap 更高效灵活,适合单线程或需手动处理线程安全的场景;HashTable 较古老,线程安全但性能不佳。现代项目推荐使用 ConcurrentHashMap。关注我的公众号“软件求生”,获取更多技术干货!
27 3
|
22天前
|
存储 缓存 安全
Java 集合江湖:底层数据结构的大揭秘!
小米是一位热爱技术分享的程序员,本文详细解析了Java面试中常见的List、Set、Map的区别。不仅介绍了它们的基本特性和实现类,还深入探讨了各自的使用场景和面试技巧,帮助读者更好地理解和应对相关问题。
39 5
|
2月前
|
存储 缓存 安全
Java 集合框架优化:从基础到高级应用
《Java集合框架优化:从基础到高级应用》深入解析Java集合框架的核心原理与优化技巧,涵盖列表、集合、映射等常用数据结构,结合实际案例,指导开发者高效使用和优化Java集合。
44 4
|
2月前
|
Java
Java 8 引入的 Streams 功能强大,提供了一种简洁高效的处理数据集合的方式
Java 8 引入的 Streams 功能强大,提供了一种简洁高效的处理数据集合的方式。本文介绍了 Streams 的基本概念和使用方法,包括创建 Streams、中间操作和终端操作,并通过多个案例详细解析了过滤、映射、归并、排序、分组和并行处理等操作,帮助读者更好地理解和掌握这一重要特性。
37 2
|
2月前
|
存储 Java
判断一个元素是否在 Java 中的 Set 集合中
【10月更文挑战第30天】使用`contains()`方法可以方便快捷地判断一个元素是否在Java中的`Set`集合中,但对于自定义对象,需要注意重写`equals()`方法以确保正确的判断结果,同时根据具体的性能需求选择合适的`Set`实现类。
|
2月前
|
安全 Java
Java多线程集合类
本文介绍了Java中线程安全的问题及解决方案。通过示例代码展示了使用`CopyOnWriteArrayList`、`CopyOnWriteArraySet`和`ConcurrentHashMap`来解决多线程环境下集合操作的线程安全问题。这些类通过不同的机制确保了线程安全,提高了并发性能。
|
2月前
|
存储 Java 开发者
在 Java 中,如何遍历一个 Set 集合?
【10月更文挑战第30天】开发者可以根据具体的需求和代码风格选择合适的遍历方式。增强for循环简洁直观,适用于大多数简单的遍历场景;迭代器则更加灵活,可在遍历过程中进行更多复杂的操作;而Lambda表达式和`forEach`方法则提供了一种更简洁的函数式编程风格的遍历方式。
|
2月前
|
Java 开发者
|
2月前
|
NoSQL Java Redis
List集合按照由小到大排序或者由大到小排序
List集合按照由小到大排序或者由大到小排序
49 0
|
2月前
|
存储 Java 开发者
Java中的集合框架深入解析
【10月更文挑战第32天】本文旨在为读者揭开Java集合框架的神秘面纱,通过深入浅出的方式介绍其内部结构与运作机制。我们将从集合框架的设计哲学出发,探讨其如何影响我们的编程实践,并配以代码示例,展示如何在真实场景中应用这些知识。无论你是Java新手还是资深开发者,这篇文章都将为你提供新的视角和实用技巧。
37 0