面试高频知识点:1集合 1.1HashSet集合的特点

HashSet(哈希集合)是Java集合框架中的一种实现Set接口的类,它具有以下特点:

  1. 无序性: HashSet不保证元素的顺序,即元素在集合中的存储顺序与它们的插入顺序无关。这是因为HashSet使用哈希表来存储元素,而哈希表不维护元素的顺序。

  2. 唯一性: HashSet中不能包含重复的元素。如果尝试将已经存在的元素添加到HashSet中,操作将被忽略,不会导致集合发生变化。

  3. 基于哈希表: HashSet内部使用哈希表实现,这使得查找、插入和删除元素的操作具有较高的效率。哈希表通过将元素的键(即哈希码)映射到存储位置来实现这些操作。

  4. 允许null元素: HashSet允许存储null元素,但是只能存储一个null元素,因为集合中不能包含重复的元素。

  5. 非同步性: HashSet不是线程安全的,如果多个线程同时访问一个HashSet实例,且至少有一个线程修改了集合,那么它必须保持外部同步。

下面是一个简单的例子,演示了如何使用HashSet:

import java.util.HashSet;

public class HashSetExample {
    public static void main(String[] args) {
        // 创建一个HashSet
        HashSet hashSet = new HashSet<>();

        // 添加元素
        hashSet.add("Apple");
        hashSet.add("Banana");
        hashSet.add("Orange");

        // 添加重复元素,将被忽略
        hashSet.add("Apple");

        // 添加null元素
        hashSet.add(null);

        // 打印HashSet
        System.out.println("HashSet: " + hashSet);
    }
}

在上面的例子中,HashSet包含了三个不同的字符串元素和一个null元素。输出结果可能类似于:HashSet: [null, Orange, Banana, Apple],展示了HashSet的无序性。

你可能感兴趣的:(面试高频知识点,面试,java)