1. 概述

Java 中的Set和正好和数学上直观的集(set)的概念是相同的。Set最大的特性就是不允许在其中存放的元素是重复的。根据这个特点,我们就可以使用Set 这个接口来实现前面提到的关于商品种类的存储需求。Set 可以被用来过滤在其他集合中存放的元素,从而得到一个没有包含重复新的集合。

2. 常用方法

按照定义,Set 接口继承 Collection 接口,而且它不允许集合中存在重复项。所有原始方法都是现成的,没有引入新方法。具体的 Set 实现类依赖添加的对象的 equals() 方法来检查等同性。

各个方法的作用描述:

public int size() :返回set中元素的数目,如果set包含的元素数大于Integer.MAX_VALUE,返回Integer.MAX_VALUE;

public boolean isEmpty() :如果set中不含元素,返回true ;
        public boolean contains(Object o) :如果set包含指定元素,返回true ;
        public Iterator iterator() : 返回set中元素的迭代器,元素返回没有特定的顺序,除非set提高该保证的某些类的实例 ;
        public boolean add(Object o) :如果set中不存在指定元素,则向set加入 ;
        public boolean remove(Object o) :如果set中存在指定元素,则从set中删除 ;
        public boolean removeAll(Collection c) :如果set包含指定集合,则从set中删除指定集合的所有元素 ;
        public void clear() :从set中删除所有元素;

3. 原理分析

HashSet的元素存放顺序和添加进去时候的顺序没有任何关系;而LinkedHashSet 则保持元素的添加顺序;TreeSet则是对我们的Set中的元素进行排序存放。 
        一般来说,当要从集合中以有序的方式抽取元素时,TreeSet 实现就会有用处。为了能顺利进行,添加到 TreeSet 的元素必须是可排序的。 而同样需要对添加到TreeSet中的类对象实现 Comparable 接口的支持。对于Comparable接口的实现。假定一棵树知道如何保持 java.lang 包装程序器类元素的有序状态。一般说来,先把元素添加到 HashSet,再把集合转换为 TreeSet 来进行有序遍历会更快。这点和HashMap的使用非常的类似。 
        其实Set的实现原理是基于Map上面的。Set中很多实现类和Map中的一些实现类的使用上非常的相似。Map中的“键值对”,其中的 “键”是不能重复的。这个和Set中的元素不能重复一致,其实Set利用的就是Map中“键”不能重复的特性来实现的。 HashSet的巧妙实现:就是建立一个“键值对”,“键”就是我们要存入的对象,“值”则是一个常量。这样可以确保, 我们所需要的存储的信息之是“键”。而“键”在Map中是不能重复的,这就保证了我们存入Set中的所有的元素都不重复。而判断是否添加元素成功,则是通 过判断我们向Map中存入的“键值对”是否已经存在,如果存在的话,那么返回值肯定是常量:PRESENT ,表示添加失败。如果不存在,返回值就为null 表示添加成功。

Java中的Set集合类相关推荐

  1. 【Java中常用的集合类】

    1.Java中集合框架图 2.List 和 Set 的区别? List , Set 都是继承自Collection 接口 List 特点:一个有序(元素存入集合的顺序和取出的顺序一致)容器,元素可以重 ...

  2. Java中的集合类--复习

    10.1 集合类与数据容器 Java用集合类来容纳不同种类的数据,这种容纳是建立在未知的基础上,即Java要用有限种类的集合类,来容纳无限种类的数据对象. ¯      分类 µ     以数组为代表 ...

  3. 5 java中的集合类_java基础(5)-集合类1

    集合的由来 数组是很常用的一种数据结构,但假如我们遇到以下这样的的问题: 容器长度不确定 能自动排序 存储以键值对方式的数据 如果遇到这样的情况,数组就比较难满足了,所以也就有了一种与数组类似的数据结 ...

  4. java中的集合_你真的了解Java中的集合类么?

    Java中的集合类很多,有各种List,各种Map,各种Set.那么这么多类,我们怎么来区分它们呢? 我们来看某个集合类是以什么结尾的,如果以List结尾,那说明这个集合类的本质就是一个List,Li ...

  5. java中的集合_Java 集合介绍,常用集合类

    JAVA 集合 在处理数据的过程中经常会需要一个容器来存储某一类型的数据,Java 中的数组就是这样一种容器.但 Java 中的数组有其局限性,定义后的数组长度不可变,超出数组长度后就不能再存放数据了 ...

  6. 集合类 Java中的集合类解析和一些有深入的面试题

    Java集合类解析 List.Map.Set三个接口,存取元素时,各有什么特点? List 以特定次序来持有元素,可有重复元素.Set 无法拥有重复元素,内部排序.Map 保存key-value值,v ...

  7. Java中的集合类——HashMap中的并发死链

    Java中的集合类--HashMap中的并发死链 ReHash过程 正常的ReHash过程: 并发的Rehash过程 解决办法 ReHash过程 正常的ReHash过程: 并发的Rehash过程 (1 ...

  8. java中集合类的一些简单总结

    本人这几天在一本java教学教材中看到有集合类这一词,这到底是干嘛的,会不会是和数组一样保存多个对象,然后也可以从中取一些元素??? 我先做了一张图,这样集合类各个接口各个实现类的关系就清晰了, 集合 ...

  9. JAVA中集合类概述

    目录 前言 一.集合类概述 二.Collection 1.List实现 2.set实现 三.Map 总结 前言 这篇文章是根据张席主编的<JAVA语言程序设计教程>提炼出来的一些JAVA中 ...

最新文章

  1. 造句简单_零基础也能说一口流利英语,用简单的you are造句学英语
  2. 7个建议帮你完成更多的工作
  3. centos磁盘空间满查询和移动命令小记
  4. 让 .NET 程序 Autorun
  5. Nacos如何支撑阿里内部数十万服务注册压力?
  6. Redis命令——键(key)
  7. ZOJ3826 Hierarchical Notation(14牡丹江 H) 树套树
  8. jquery原型方法map的使用和源码分析
  9. 测试自动化金字塔在软件开发中是如何使用的?
  10. pymssql的简单使用
  11. 控制台应用程序的Main方法
  12. LBMALL V3.1.1 多用户商城系统功能说明
  13. C++中关于使用while(cin)后,后续代码无法执行问题
  14. C#一个方法返回多个值
  15. php网站友链直显代码,discuz 友情链接 代码
  16. 数据看板是什么,怎么做?
  17. 实验数据处理的基本方法
  18. 中国机器视觉产业全景图谱
  19. excel调查问卷的录入
  20. Cantor(有理数)

热门文章

  1. 【计算机网络】网络层 : ICMP 协议 ( ICMP 差错报文 | 差错报文分类 | ICMP 询问报文 | ICMP 应用 | Ping | Traceroute )
  2. 【C++ 语言】容器 ( queue 队列 | stack 栈 | priority_queue 优先级队列 | set 集合 | 容器遍历 | map )
  3. 使用SQLite学习SQL
  4. jinja2的url_for 和数据块
  5. Hadoop-2.8.5的HA集群搭建
  6. 恐龙拼图游戏 - 恐龙拼图乐园积木游戏
  7. Hibernate 一对一关联关系
  8. 个人阅读作业Week7
  9. Lucene4.3和Lucene3.5性能对比(一)
  10. CentOS7 minimal 没有netstat命令