HashSet、LinkedHashSet和TreeSet
- 关键技术:
- HashSet采用散列函数对元素进行排序,是专门为快速查询而设计的。存入HashSet的对象必须定义hashCode方法。
- TreeSet采用红黑树的数据结构进行排序元素,使用它可以从Set中提取有序(升序或者降序)的序列。需要注意的是,存入自定义类时,TreeSet需要维护元素的存储顺序,因此自定义类要实现Comparable接口并定义compareTo方法。
- LinkedHashSet内部使用散列以加快查询速度,同时使用链表维护元素插入的次序,在使用迭代器遍历Set时,结果会按元素插入的次序显示。
关键技术:
HashSet采用散列函数对元素进行排序,是专门为快速查询而设计的。存入HashSet的对象必须定义hashCode方法。
TreeSet采用红黑树的数据结构进行排序元素,使用它可以从Set中提取有序(升序或者降序)的序列。需要注意的是,存入自定义类时,TreeSet需要维护元素的存储顺序,因此自定义类要实现Comparable接口并定义compareTo方法。
LinkedHashSet内部使用散列以加快查询速度,同时使用链表维护元素插入的次序,在使用迭代器遍历Set时,结果会按元素插入的次序显示。
- package book.arrayset;
- import java.util.ArrayList;
- import java.util.HashSet;
- import java.util.Iterator;
- import java.util.LinkedHashSet;
- import java.util.List;
- import java.util.Set;
- import java.util.TreeSet;
- /**
- * 演示各种Set的使用
- * 存入Set的每个元素必须是唯一的,因为Set不保存重复元素。
- */
- public class TestSet {
- /**
- * 初始化Set的元素
- * @param set
- */
- public static void init(Set set){
- if (set != null){
- set.add("aaa");
- set.add("ccc");
- set.add("bbb");
- set.add("eee");
- set.add("ddd");
- }
- }
- /**
- * 输出set的元素
- * @param set
- */
- public static void output(Set set){
- if (set != null){
- //使用迭代器遍历Set,也只有这一种方法
- Iterator it = set.iterator();
- while (it.hasNext()){
- System.out.print(it.next() + " ");
- }
- }
- System.out.println();
- }
- /**
- * 使用HashSet
- */
- public static void testHashSet(){
- Set mySet = new HashSet();
- init(mySet);
- System.out.println("使用HashSet: ");
- output(mySet);
- }
- /**
- * 使用TreeSet
- */
- public static void testTreeSet(){
- Set mySet = new TreeSet();
- init(mySet);
- System.out.println("使用TreeSet: ");
- output(mySet);
- }
- /**
- * 使用LinkedHashSet
- */
- public static void testLinkedHashSet(){
- Set mySet = new LinkedHashSet();
- init(mySet);
- System.out.println("使用LinkedHashSet: ");
- output(mySet);
- }
- public static void main(String[] args) {
- TestSet.testHashSet();
- TestSet.testTreeSet();
- TestSet.testLinkedHashSet();
- Set mySet = new HashSet();
- init(mySet);
- //Set不允许元素重复
- mySet.add("aaa");
- mySet.add("bbb");
- System.out.println("为mySet加入aaa, bbb元素后: ");
- output(mySet);
- //删除元素
- mySet.remove("aaa");
- System.out.println("mySet删除aaa元素后: ");
- output(mySet);
- //增加另外一个集合中的所有元素
- List list = new ArrayList();
- list.add("aaa");
- list.add("aaa");
- list.add("fff");
- mySet.addAll(list);
- System.out.println("mySet添加另外一个集合的所有元素后: ");
- output(mySet);
- //删除除了另外一个集合包含的以外的所有元素
- mySet.retainAll(list);
- System.out.println("mySet删除除了另外一个集合包含的以外的所有元素后: ");
- output(mySet);
- //删除另外一个集合包含的所有元素
- mySet.removeAll(list);
- System.out.println("mySet删除另外一个集合包含的所有元素后: ");
- output(mySet);
- //获取Set中元素的个数
- System.out.println("mySet中当前元素的个数: " + mySet.size());
- //判断Set中元素个数是否为0
- System.out.println("mySet中当前元素为0? " + mySet.isEmpty());
- /**
- * (1)Set不允许重复元素,因此加入Set的Object必须定义equals()方法以确保对象的唯一性。
- * (2)HashSet采用散列函数对元素进行排序,是专门为快速查询而设计的。存入HashSet的对象必须定义hashCode()。
- * (3)TreeSet采用红黑树的数据结构进行排序元素,能保证元素的次序,使用它可以从Set中提取有序的序列。
- * 需要注意的是,生成自己的类时,Set需要维护元素的存储顺序,因此要实现Comparable接口并定义compareTo()方法。
- * (4)LinkedHashSet内部使用散列以加快查询速度,同时使用链表维护元素的插入的次序,在使用迭代器遍历Set时,结果会按元素插入的次序显示。
- */
- }
- }
HashSet、LinkedHashSet和TreeSet的更多相关文章
- HashSet、LinkedHashSet、TreeSet
以下内容基于jdk1.7.0_79源码: 关于HashSet.LinkedHashSet.TreeSet Set接口的实现类,最大特点是不允许出现重复元素: HashSet:基于HashMap实现,一 ...
- 规则集之探究何时使用HashSet、LinkedHashSet以及TreeSet?
前言 Java集合框架三种主要类型的集合:规则集(Set).线性表(List).队列(Queue).Set用来存储不可重复的元素:List用来存储有元素构成的有序的集合:而Queue则用于存储用先进先 ...
- Java集合框架(二)—— HashSet、LinkedHashSet、TreeSet和EnumSet
Set接口 前面已经简绍过Set集合,它类似于一个罐子,一旦把对象'丢进'Set集合,集合里多个对象之间没有明显的顺序.Set集合与Collection基本上完全一样,它没有提供任何额外的方法. Se ...
- 一、集合框架(关于ArrayList,LinkedList,HashSet,LinkedHashSet,TreeSet)
一.ArrayList 解决了数组的局限性,最常见的容器类,ArrayList容器的容量capacity会随着对象的增加,自动增长.不会出现数组边界的问题. package collection; ...
- 09 Collection,Iterator,List,listIterator,Vector,ArrayList,LinkedList,泛型,增强for,可变参数,HashSet,LinkedHashSet,TreeSet
09 Collection,Iterator,List,listIterator,Vector,ArrayList,LinkedList,泛型,增强for,可变参数,HashSet,LinkedHas ...
- java集合框架之几种set(HashSet LinkedHashSet TreeSet )
参考http://how2j.cn/k/collection/collection-sets/691.html#nowhere HashSet LinkedHashSet TreeSet HashSe ...
- Java集合系列(三):HashSet、LinkedHashSet、TreeSet的使用方法及区别
本篇博客主要讲解Set接口的三个实现类HashSet.LinkedHashSet.TreeSet的使用方法以及三者之间的区别. 注意:本文中代码使用的JDK版本为1.8.0_191 1. HashSe ...
- Java中的集合HashSet、LinkedHashSet、TreeSet和EnumSet(二)
Set接口 前面已经简绍过Set集合,它类似于一个罐子,一旦把对象'丢进'Set集合,集合里多个对象之间没有明显的顺序.Set集合于Collection基本上完全一样,它没有提供任何额外的方法. Se ...
- Java自学-集合框架 HashSet、LinkedHashSet、TreeSet之间的区别
HashSet. LinkedHashSet.TreeSet之间的区别 步骤 1 : HashSet LinkedHashSet TreeSet HashSet: 无序 LinkedHashSet: ...
- Java Set 常用集合 HashSet、LinkedHashSet、TreeSet
Java 中的 Set 是非常常用的数据类型.Set 是无序的 Collection,Java Set 有三个常用的实现类,分别是:HashSet.LinkedHashSet.TreeSet 本文基于 ...
随机推荐
- 自动化测试学习之路--json、dom编程
1.json: json是JavaScript Object Notation,是一种数据传输格式. 以下程序都是在浏览器的Console下执行的. 创建一个javaScript的对象: var st ...
- Jmeter编码问题
问题现象:1.利用csv data set config参数化数据后,在beanshell中引用,能正常引用到,但是传给服务器时,还是报手机号格式不对 将jmeter日志级别打成debug(jmete ...
- mysql用root账户建立用户和赋予权限
1.创建用户 create user guest_test@localhost identified by "root";-- 创建名为guest_test的用户 2.赋予权限 - ...
- 更换checkbox的原有样式
通常情况下,各个浏览器对的样式不一致,并且不那么美观.所以有时候设计需要我们更换原有的样式: html: <span><input type="checkbox" ...
- $this和self、parent这三个关键词分别代表什么?在哪些场合下使用?
$this:当前对象 self: 当前类 parent: 当前类的父类 $this在当前类中使用,使用->调用属性和方法. self也在当前类中使用,不过需要使用::调用. 静态属性,不能在类里 ...
- html5 download blob
html5 download blob https://stackoverflow.com/questions/19327749/javascript-blob-filename-without-li ...
- Redis客户端命令
Redis客户端命令 Redis 命令用于在 redis 服务上执行操作. 要在 redis 服务上执行命令需要一个 redis 客户端.Redis 客户端在我们之前下载的的 redis 的安装包中. ...
- android中常见的Drawable资源有哪些?
Drawable资源是安卓应用中最常见的一种资源,比如图片等,因此,对于初学者而言,必须掌握drawable资源相关应用. 今天在网上刚好看到了一篇介绍android Drawable资源的文章,分享 ...
- Maven项目消除奇怪的红叉
当项目截然无误,然则Eclipse总是出现红叉的时候,右键点击项目->Maven->Update Project-,进而纠正之.很简答的操作. 木头大哥所发的文章均基于自身实践,各位江湖好 ...
- Tomcat学习笔记(十三)
服务器组件和服务组件 服务器组件 org.apache.catalina.Server接口的实例表示Catalina的整个servlet引擎,包含了所有的组件.使用一种优雅的方法来启动/关闭整个系统, ...