jdk1.8中HashSet与LinkedHashSet源码分析

注:基于JDK 1.8.0_131源码为例进行分析:

一、HashSet分析

1.1 HashSet的实现

  HashSet实现set接口,是基于HashMap或者LinkedHashMap实现的
  HashSet中封装了一个 HashMap 对象(也有可能是LinkedHashMap)来存储所有的集合元素,所有放入 HashSet 中的集合元素实际上由 HashMap 的 key 来保存,而 HashMap 的 value 则存储了一个 PRESENT,它是一个静态的 Object 对象。
  注:LinkedHashMap的实现是继承自HashMap的,所以一个LinkedHashMap对象可以复制给HashMap引用。
这里写图片描述
说明:

  • 代码块1:HashSet的实现是由HashMap<E,Object>类型的map实现。所以放入hashset集合的元素均存进了map的key中。
  • 代码块2:map中的每一个键值对<key,value>的value值均为该静态Object对象PRESENT。

1.2 HashSet中选择用HashMap还是LinkedHashMap实现?

这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
结论:

  • A:前三个构造函数,即访问权限为public类型的构造函数均是以HashMap作为实现。而以LinkedHashMap作为实现的构造函数的访问权限是默认访问权限,即包内访问权限。
    即:在java编程中,通过new创建的HashSet对象均是以HashMap作为实现基础。只有在jdk中java.util包内的源代码才可能创建以LinkedHashMap作为实现的HashSet(LinkedHashSet就是通过封装一个以LinkedHashMap为实现的HashSet来实现的)。
  • B:只有包含三个参数的构造函数才是采用的LinkedHashMap作为实现。

1.3 HashSet的默认大小

这里写图片描述
说明:

  • 代码块1:HashSet中map的默认大小为HashMap的默认值,即容量为16,负载因子为0.75。
  • 代码块2:HashSet中map的容量最小值为16。

1.4 HashSet的add操作实现

这里写图片描述
即直接将键值对<e,PRESENT>放入了hashmap中。

1.5 HashSet的contains方法实现

这里写图片描述

1.6 HashSet的迭代

注:只有实现了Iterable接口的类,才能用迭代器进行遍历。
这里写图片描述
HashSet的中迭代器迭代是基于HashMap的KeySet实现的。

1.7 HashSet的序列化定制

这里写图片描述

1.8 HashSet的用处?

1、 可以在HashSet集合中存储不重复的元素。如果加入重复元素会自动覆盖。
2、 HashSet中可以出现一个为null元素。
3、 因为用new创建的HashSet对象中采用HashMap实现时,则不能保证集合中元素的顺序,即顺序是无序的。

二、LinkedHashSet分析

2.1 LinkedHashSet是通过继承HashSet进行实现的

这里写图片描述

2.2 LinkedHashSet是通过构造一个具有三个参数的HashSet进行实现的。

这里写图片描述
即:LinkedHashSet是通过继承HashSet,然后基于LinkedHashMap进行实现的

2.3 HashSet与LinkedHashSet对比总结

  • A:HashSet的public类型构造函数均是采用HashMap实现,所以HashSet能够存储不重复的对象,包括NULL。
  • B:LinkedHashSet通过继承HashSet,采用LinkedhashMap进行实现,所以LinkedHashSet除了具有HashSet的功能外,还能保证元素按照加入顺序进行排序。
        LinkedHashSet<Integer> linkedHashSet = new LinkedHashSet<>();
        linkedHashSet.add(11);
        linkedHashSet.add(33);
        linkedHashSet.add(44);
        linkedHashSet.add(22);
        linkedHashSet.add(55);

        System.out.println("LinkedHashSet输出结果:");
        for (Integer integer : linkedHashSet) {
            System.out.print(integer+" ");
        }
        System.out.println();

        HashSet<Integer> hashSet = new HashSet<>();
        hashSet.add(11);
        hashSet.add(33);
        hashSet.add(44);
        hashSet.add(22);
        hashSet.add(55);

        System.out.println("HashSet输出结果:");
        for (Integer integer : hashSet) {
            System.out.print(integer+" ");
        }
        System.out.println();

运行结果:

LinkedHashSet输出结果:
11 33 44 22 55 
HashSet输出结果:
33 22 55 11 44 

由结果可以看出,LinkedHashSet是按照加入顺序进行排序的。

### 回答1: 在JDK 1.8,API文档是用英文编写的,但是我可以为你提供一些英文和文对照的示例。 1. Object类 (Object class) - equals()方法: 判断两个对象是否相等。 - toString()方法: 返回对象的字符串表示。 - hashCode()方法: 返回对象的哈希码值。 2. String类 (String class) - length()方法: 返回字符串的长度。 - charAt()方法: 返回指定位置的字符。 - substring()方法: 返回子串。 3. ArrayList类 (ArrayList class) - add()方法: 将元素添加到ArrayList。 - get()方法: 获取指定位置的元素。 - remove()方法: 删除指定位置的元素。 4. HashMap类 (HashMap class) - put()方法: 将键值对添加到HashMap。 - get()方法: 根据键获取对应的值。 - remove()方法: 根据键删除键值对。 5. DateTimeFormatter类 - parse()方法: 将字符串解析为日期时间对象。 - format()方法: 将日期时间对象格式化为字符串。 请注意,这只是一小部分JDK 1.8 API的方法示例,整个API文档提供了更多详细的说明和示例。您可以参考官方的JDK 1.8 API文档以获取更全面的信息。 ### 回答2: 1. java.lang 包下的常用类: - Object:对象类 - Class:类类 - String:字符串类 - StringBuilder:字符串构建器类 - StringBuffer:字符串缓冲类 - System:系统类,提供与系统相关的方法和属性 - Math:数学类,提供数学相关的方法和常量 - Boolean:布尔类 - Byte:字节类 - Character:字符类 - Short:短整数类 - Integer:整数类 - Long:长整数类 - Float:单精度浮点数类 - Double:双精度浮点数类 - Enum:枚举类 - Throwable:可抛出对象类,是所有错误和异常的基类 2. java.util 包下的常用类: - ArrayList:动态数组类 - LinkedList:链表类 - HashMap:哈希映射类 - LinkedHashMap:有序哈希映射类 - TreeSet:树集类 - TreeMap:树映射类 - HashSet:哈希集合类 - LinkedHashSet:有序哈希集合类 - Queue:队列接口 - PriorityQueue:优先队列类 - Stack:栈类 - Iterator:迭代器接口 - ListIterator:列表迭代器接口 - Comparator:比较器接口 - Calendar:日历类 - Date:日期类 - Timer:定时器类 3. java.io 包下的常用类: - File:文件类 - InputStream:输入流接口 - OutputStream:输出流接口 - Reader:字符输入流接口 - Writer:字符输出流接口 - BufferedReader:缓冲字符输入流类 - BufferedWriter:缓冲字符输出流类 - FileReader:文件字符输入流类 - FileWriter:文件字符输出流类 - FileInputStream:文件字节输入流类 - FileOutputStream:文件字节输出流类 - ObjectInputStream:对象输入流类 - ObjectOutputStream:对象输出流类 - PrintWriter:打印输出流类 - RandomAccessFile:随机访问文件类 - ByteArrayInputStream:字节数组输入流类 - ByteArrayOutputStream:字节数组输出流类 - CharArrayReader:字符数组输入流类 - CharArrayWriter:字符数组输出流类 这些只是jdk1.8 API的一部分常用类和接口,还有很多其他类和接口不一一列举。 ### 回答3: JDK 1.8的API是指Java开发工具包1.8版本提供的所有类、接口和方法,它们用于开发Java应用程序。下面是一些常用API的英文对照: 1. java.lang包: - Object: 对象 - String: 字符串 - Integer: 整型 - Double: 双精度浮点型 - Math: 数学计算 2. java.util包: - ArrayList: 数组列表 - LinkedList: 链表 - HashMap: 哈希表 - TreeSet: 树集合 - PriorityQueue: 优先队列 3. java.io包: - File: 文件 - InputStream: 输入流 - OutputStream: 输出流 - BufferedReader: 缓冲读取器 - BufferedWriter: 缓冲写入器 4. java.awt包: - Frame: 框架 - Button: 按钮 - Label: 标签 - TextField: 文本框 - Checkbox: 复选框 5. java.net包: - Socket: 套接字 - ServerSocket: 服务器套接字 - URL: 统一资源定位符 - HttpURLConnection: HTTP连接 这只是JDK 1.8 API一小部分常用类和接口的英文对照,实际上API包含了更多的类和接口,用于满足不同的编程需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值