Java 之集合框架的详细介绍

在这里插入图片描述

Java 集合框架提供了一组实现常见数据结构(如列表、集合、映射等)的类和接口,使得数据的存储、检索、操作更加方便和高效。集合框架主要包括以下核心接口和类:

总的介绍

1. Collection 接口

Collection 接口是集合框架的根接口,它定义了一组通用的方法,适用于所有集合类。主要有:

  • add(E e): 将指定的元素添加到集合中。
  • remove(Object o): 从集合中移除指定的元素。
  • size(): 返回集合中的元素数量。
  • isEmpty(): 判断集合是否为空。
  • contains(Object o): 判断集合是否包含指定的元素。
  • iterator(): 返回一个迭代器,用于遍历集合中的元素。

2. List 接口

List 接口继承自 Collection 接口,表示有序的集合,允许重复元素。主要特点是可以通过索引访问元素。常用的实现类有 ArrayListLinkedListVector

3. Set 接口

Set 接口继承自 Collection 接口,表示不允许重复元素的集合。主要特点是不维护元素的顺序。常用的实现类有 HashSetLinkedHashSetTreeSet

4. Map 接口

Map 接口表示键值对的集合,每个键关联一个值。键不能重复,但值可以。主要方法包括:

  • put(K key, V value): 将指定的键值对存储到 Map 中。
  • get(Object key): 返回与指定键关联的值。
  • remove(Object key): 从 Map 中移除指定键的映射。
  • containsKey(Object key): 判断 Map 中是否包含指定的键。
  • containsValue(Object value): 判断 Map 中是否包含指定的值。

5. HashMap、LinkedHashMap、TreeMap

  • HashMap: 基于哈希表实现,提供快速的检索性能,无固定顺序。
  • LinkedHashMap:HashMap 基础上,保持元素插入顺序。
  • TreeMap: 基于红黑树实现,按键有序存储。

6. Queue 接口

Queue 接口表示一种先进先出(FIFO)的数据结构,通常用于处理任务调度。主要方法包括 offer(E e)poll()peek()

7. Deque 接口

Deque 接口是 Queue 接口的扩展,表示一种双端队列。可以在两端插入和删除元素。主要方法包括 addFirst(E e)addLast(E e)removeFirst()removeLast()

ArrayList 类

当使用 ArrayList 类时,您可以执行许多常见的操作,例如添加、获取、修改、删除元素以及其他一些集合操作。以下是 ArrayList 类的详细使用说明:

1. 创建 ArrayList:

import java.util.ArrayList;

public class ArrayListUsage {
    public static void main(String[] args) {
        // 创建一个 ArrayList
        ArrayList<String> cityList = new ArrayList<>();
    }
}

2. 添加元素:

使用 add 方法向 ArrayList 中添加元素。

cityList.add("Beijing");
cityList.add("Shanghai");
cityList.add("Guangzhou");

3. 插入元素:

使用 add 方法的指定索引位置,将元素插入 ArrayList。

cityList.add(1, "Chengdu");

4. 获取元素:

使用 get 方法通过索引获取元素。

String city = cityList.get(0);

5. 修改元素:

使用 set 方法通过索引修改元素。

cityList.set(1, "Nanjing");

6. 删除元素:

使用 remove 方法通过元素值或索引删除元素。

cityList.remove("Guangzhou");
cityList.remove(0);

7. 查找元素:

使用 contains 方法判断 ArrayList 中是否包含某个元素。

boolean containsChengdu = cityList.contains("Chengdu");

8. 获取大小:

使用 size 方法获取 ArrayList 的大小。

int cityCount = cityList.size();

9. 遍历 ArrayList:

使用 for-each 循环遍历 ArrayList。

for (String city : cityList) {
    System.out.println(city);
}

完整示例:

import java.util.ArrayList;

public class ArrayListUsage {
    public static void main(String[] args) {
        // 创建一个 ArrayList
        ArrayList<String> cityList = new ArrayList<>();

        // 添加元素
        cityList.add("Beijing");
        cityList.add("Shanghai");
        cityList.add("Guangzhou");

        // 插入元素
        cityList.add(1, "Chengdu");

        // 获取元素和修改元素
        String firstCity = cityList.get(0);
        cityList.set(1, "Nanjing");

        // 删除元素
        cityList.remove("Guangzhou");
        cityList.remove(0);

        // 查找元素
        boolean containsChengdu = cityList.contains("Chengdu");

        // 获取大小
        int cityCount = cityList.size();

        // 遍历 ArrayList
        System.out.println("遍历城市列表:");
        for (String city : cityList) {
            System.out.println(city);
        }
    }
}

这个示例演示了如何使用 ArrayList 进行添加、获取、修改、删除元素以及其他一些集合操作。

set接口以及实现类

HashSet 类

明白了,以下是更简洁的介绍:

创建 HashSet:

Set<String> hashSet = new HashSet<>();

添加元素:

hashSet.add("Apple");
hashSet.add("Banana");
hashSet.add("Orange");

查找元素:

boolean containsBanana = hashSet.contains("Banana");

删除元素:

hashSet.remove("Orange");

获取大小:

int setSize = hashSet.size();

遍历 HashSet:

for (String fruit : hashSet) {
    System.out.println(fruit);
}

这些简单的代码片段展示了 HashSet 的基本操作,包括创建、添加、查找、删除、获取大小和遍历。

用Set 对象实现集合运算

1. 并集(Union):

Set<Integer> unionSet = new HashSet<>(set1);
unionSet.addAll(set2);

2. 交集(Intersection):

Set<Integer> intersectionSet = new HashSet<>(set1);
intersectionSet.retainAll(set2);

3. 差集(Difference):

Set<Integer> differenceSet = new HashSet<>(set1);
differenceSet.removeAll(set2);

判断是否为子集:

boolean isSubset = set1.containsAll(set2);

这行代码判断 set2 是否为 set1 的子集,如果是,则 isSubsettrue

TreeSet 类

创建 TreeSet:

Set<String> treeSet = new TreeSet<>();

添加元素:

treeSet.add("Apple");
treeSet.add("Banana");
treeSet.add("Orange");

查找第一个元素:

String firstElement = ((TreeSet<String>) treeSet).first();

删除元素:

treeSet.remove("Orange");

获取大小:

int treeSetSize = treeSet.size();

遍历 TreeSet:

for (String fruit : treeSet) {
    System.out.println(fruit);
}

这些简洁的代码片段展示了 TreeSet 的基本操作,包括创建、添加、查找、删除、获取大小和遍历。

对象顺序

在 Java 中,对象的顺序通常涉及到两个方面:插入顺序和排序顺序。

  1. 插入顺序(Insertion Order): 插入顺序指的是元素被添加到集合的顺序。例如,如果你按照顺序添加元素 A、B、C 到集合中,那么在遍历集合时,元素的顺序将是 A、B、C。

    示例:

    Set<String> insertionOrderSet = new HashSet<>();
    insertionOrderSet.add("Apple");
    insertionOrderSet.add("Banana");
    insertionOrderSet.add("Orange");
    
    for (String fruit : insertionOrderSet) {
        System.out.println(fruit);
    }
    

    输出可能是:

    Apple
    Banana
    Orange
    
  2. 排序顺序(Sorting Order): 排序顺序指的是元素按照一定的顺序排列。在有序的集合中,元素通常按照升序或降序排列。TreeSet 就是一个有序集合的例子,它使用红黑树数据结构来保持元素的顺序。

    示例:

    Set<String> sortingOrderSet = new TreeSet<>();
    sortingOrderSet.add("Apple");
    sortingOrderSet.add("Banana");
    sortingOrderSet.add("Orange");
    
    for (String fruit : sortingOrderSet) {
        System.out.println(fruit);
    }
    

    输出可能是:

    Apple
    Banana
    Orange
    

需要注意的是,有些集合类(如 HashSet)并不保证元素的排序,而有些集合类(如 TreeSet)则明确保持元素的排序。在选择集合类时,可以根据对顺序的需求来选择合适的实现。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值