Java精选笔记_集合【Set(集合)接口】
Set(集合)接口
简介
同样继承自Collection接口,它与Collection接口中的方法基本一致,并没有对Collection接口进行功能上的扩充,只是比Collection接口更加严格了。
元素是有序的,元素值唯一,不允许重复。
HashSet集合
HashSet是Set接口的一个实现类,它所存储的元素是不可重复的,并且元素都是无序的。
当向HashSet集合中添加一个对象时,首先会调用该对象的hashCode()方法来确定元素的存储位置,然后再调用对象的equals()方法来确保该位置没有重复元素。
底层数据结构式哈希表,是通过元素的hashcode和equals来保证元素的唯一性。
如果元素的hashcode值相同(有对象存在),才会判断equals是否为true(是否重复true表示重复);如果元素的hashcode的值不同(该位置没对象存在),不会调用equals,直接将该对象存入集合。
对于判断元素是否存在,以及删除等操作,依赖的方法是元素的hashcode和equals方法。
hashSet使用 :
HashSet hs=new HashSet();
hs.add();
Iterator it=hs.iterator();
while(it.hasNext) {
it.next();
}
往HashSet集合中存入自定义对象,姓名和年龄相同为同一个人。
复写equals和hashcode方法
public boolean equals(Object obj){
if(!(obj.instanceof Person))
return false;
Person p= (Person)obj;
return this.getname().equals(p.getname())&&this.getage()==p.getage();
}
//复写hashcode方法
public int hashCode() {
return name.hashcode+age*12;
}
HashSet是根据对象的哈希值来确定元素在集合中的存储的位置,因此具有良好的存取和查找性能。
HashSet类是对AbstractSet类的扩展。它创建了一个类集。该类集使用散列表进行存储,而散列表则通过使用称之为散列法的机制来存储信息。在散列中,一个关键字的信息内容被用来确定唯一的一个值,称为散列码。而散列码则被用来当作与关键字相连的数据的存储下标。
构造方法
HashSet()方法 构造一个默认的散列集合
HashSet(Collection c)方法 用类c中的元素初始化散列集合
HashSet(int initialCapacity) 方法 用capacity初始化散列集合的容量
HashSet(int initialCapacity, float fillRatio)方法 用参数初始化散列集合的容量和填充比(也称加载容量)
主要方法
public boolean add(E o) 向集合添加指定元素
public void clear() 清空集合中所有元素
public boolean contains(Object o) 判断集合是否包含指定元素
public boolean isEmpty() 判断集合是否还有元素。如果集合不包含任何元素,则返回true
public Iterator iterator() 返回对此集合中元素进行迭代的迭代器
public boolean remove(Object o) 删除集合中的元素
public int size() 返回此集合中的元素的个数
public Object[] toArray 将集合中的元素放到数组中,并返回该数组
TreeSet集合
TreeSet内部采用平衡二叉树来存储元素,这样的结构可以保证TreeSet集合中没有重复的元素,并且可以对元素进行排序。
可以对Set集合中的元素进行自然排序。
TreeSet则是以二叉树的方式来存储元素,它可以实现对集合中的元素进行排序。方便我们对其进行访问和检索。
所谓二叉树就是说每个节点最多有两个子节点的有序树,每个节点及其子节点组成的树称为子树
排序方式一
要让自定义对象是实现 Comparable接口,强制让对象具有比较性。排序时当主要条件相同时,一定要判断下次要条件。然后重写compareTo()方法。
如果想要按原样顺序输出,则让compareTo()方法返回 1。
TreeSet存储自定义对象:往TreeSet集合中存储自定义对象,根据学生年龄进行排序。
public int compareTo(Object obj) {
if(!obj instanceof Student) {
throw new RuntimeException("不是学生");
Student s=(Student)obj;
if(this.age>s.age)
return 1;
if(this.age==s.age)
return this.name.compareTo(s.name);
}
return -1;
}
排序方式二
当元素自身不具备比较性时,或者具备的比较性不是所需要的,这时就需要让集合自身具备比较性。
在集合初始化的时候,就让集合具有比较性。
定义比较器,将比较器作为参数传递给TreeSet集合的构造函数。
TreeSet存储自定义对象:往TreeSet集合中存储自定义对象,根据学生年龄进行排序。
排序方式二:定义一个类实现comparator接口,覆盖compare方法。让集合具备比较性
TreeSet ts=new TreeSet(new MyCompare());
class MyCompare implements Comparator {
public int compare(Object o1,Object o2) {
Student s1=(Student)o1;
Student s2=(Student)o2;
int num=s1.getName().compareTo(S2.getname());
if(num==0)
return new Integer(s1.getAge()).compareTo(new Integer(s2.getAge()));
}
}
构造方法
TreeSet()方法 构造一个空的树集合,其元素按升序排序
TreeSet(Collection c)方法 用类c中的元素初始化树集合
TreeSet(Comparator comp)方法 按照由comp指定的比较方法进行排序
TreeSet(SortedSet ss)方法 构造了一个包含了ss元素的树集合
方法
public E first() 返回有序集合中第一个元素,即最小的那个元素
public E last() 返回有序集合中最后一个元素,即最大的那个元素
public SortedSet subSet(E fromElement,E toElement) 返回有序集合从fromElement(包括)到toElement(不包括)的元素
Java精选笔记_集合【Set(集合)接口】的更多相关文章
- Java精选笔记_集合概述(Collection接口、Collections工具类、Arrays工具类)
集合概述 集合有时又称为容器,简单地说,它是一个对象,能将具有相同性质的多个元素汇聚成一个整体.集合被用于存储.获取.操纵和传输聚合的数据. 使用集合的技巧 看到Array就是数组结构,有角标,查询速 ...
- Java精选笔记_集合【Map(映射)接口】
Map(映射)接口 简介 该集合存储键值对,一对一对的往里存,并且键是唯一的.要保证map集合中键的唯一性. 从Map集合中访问元素时,只要指定了Key,就能找到对应的Value. 关键字是以后用于检 ...
- Java精选笔记_面向对象(包、访问控制、内存机制、垃圾回收机制)
包 包的定义与使用 专门用来存放类的,通常功能相同的类存放在相同的包中. 包的声明只能位于Java源文件的第一行 Java语言中的常用包 java.lang:包含Java语言的核心类,如String. ...
- Java精选笔记_集合【List(列表)接口】
List(列表)接口 简介 List接口继承自Collection接口,是单列集合的一个重要分支,习惯性地会将实现了List接口的对象称为List集合. 元素是有序的,即元素的存入顺序和取出顺序一致, ...
- Java精选笔记_文件上传与下载
文件上传与下载 如何实现文件上传 在Web应用中,由于大多数文件的上传都是通过表单的形式提交给服务器的,因此,要想在程序中实现文件上传的功能,首先得创建一个用于提交上传文件的表单页面. 为了使Serv ...
- Java精选笔记_国际化
国际化 什么是国际化 指软件在开发时就应该具备支持多种语言和地区的功能,当应对不同国家和地区的用户访问,针对不同国家和地区的用户,提供相应的.符合来访者阅读习惯的页面和数据. 由于国际化interna ...
- Java精选笔记_自定义标签
自定义标签 自定义标签入门 什么是自定义标签 自定义标签可以有效地将HTML代码与Java代码分离,从而使不懂Java编程的HTML设计人员也可以编写出功能强大的JSP页面 JSP规范中定义了多个用于 ...
- Java精选笔记_会话技术
会话及其会话技术 会话概述 指的是一个客户端(浏览器)与Web服务器之间连续发生的一系列请求和响应过程. 会话:从浏览器开启到浏览器关闭.会话技术:用来保存在会话期间 浏览器和服务器所产生的数据. 在 ...
- Java精选笔记_其他IO流(ObjectInputStream、DataInputStream、PrintStream、标准输入输出流)
其他IO流 ObjectInputStream和ObjectOutputStream 如果希望永久将对象转为字节数据写入到硬盘上,即对象序列化,可以使用ObjectOutputStream(对象输出流 ...
随机推荐
- VS2012, opencv2.4.4环境搭建
2.1 环境准备 安装 Visual Studio 2012 下载 opencv 最新版本( 目前是2.4.6, 下载链接 ) 2.2 安装 opencv 2.2.1. 双击下载的 OpenCV-2. ...
- selenium初探:WebDriverException解决方法探索(以Chrome浏览器|IE浏览器|Edge浏览器为例)
环境参考:win10-64位, python3.6.3, selenium3.7 在初试selenium运行以下代码时 from selenium import webdriver browser = ...
- Ubuntu下如何解压缩zip,tar,tar.gz,tar.bz2文件
转自:http://wangli-5665.diandian.com/post/2011-08-18/4039228 这么多年来,数据压缩对我们来说是非常有用的.无论是在邮件中发送的图片用的zip文件 ...
- js屏蔽键盘按键
3.1屏蔽键盘所有键 <script language="javascript"> <!-- function document.onkeydown(){ eve ...
- iphone 6plus 下app里的状态栏和界面会被放大的问题//以及设置APP闪屏页/APP图标流程
//设置APP闪屏页/APP图标流程如下 2.6Plus界面显示变大以及APP图标变大是由于上面图片的AppIcon以及LaunchImage造成的,主要是由于找不到对应的3x图片,或者改3x图片尺寸 ...
- MongoDB学习之(一)安装
第一步:下载MongoDB的安装版进行安装 https://pan.baidu.com/s/1X3hIqORJ61TCG1UJ_yr6ag 由于第二次安装出现一些问题,所有还是记录一下,免得以后踩坑. ...
- 千兆网口POE供电
一.IEEE802.3af与at标准的解析 链接:http://www.winchen.com.cn/ShowNews2.asp?ID=21&ClassID=1 2003 年6 月,IEEE ...
- [LintCode]转换字符串到整数
问题描述: 实现atoi这个函数,将一个字符串转换为整数.如果没有合法的整数,返回0.如果整数超出了32位整数的范围,返回INT_MAX(2147483647)如果是正整数,或者INT_MIN(-21 ...
- Struts2 的Action中取得请求参数值的几种方法
先看GetRequestParameterAction类代码: Java代码 public class GetRequestParameterAction extends ActionSupport ...
- C语言写的trim()函数
C语言的标准库中缺少对字符串进行操作的trim()函数,使用起来有些不便,可以使用利用 strlen 和 isspace 函数以及指针来自己写一个. 1.strlen 函数 原型:extern int ...