HashSet介绍

这个类实现了Set接口,背后是一个hash table(实际上是个HashMap 实例) 。它不保证元素的迭代顺序。尤其是,随着时间推

移它不保证某一元素的位置不变。这个类是非线程安全的,不过可以通过以下方式显式实现:

Set s = Collections.synchronizedSet(new HashSet(...));

HashSet特点

1)HashSet 不维护任何顺序, 元素将以随机顺序返回。

2)HashSet 不允许有重复元素, 如果你试图添加重复元素, 旧有的元素值将被覆盖

3)HashSet 允许有null值,然而如果你插入多个null它将只返回一个。

4)HashSet 是非线程安全的。

5)这个类返回的迭代器是快速失败的,也就是说如果你在创建迭代器之后又去修改HashSet,迭代器将抛出ConcurrentModificationException异常,除非你调用的是迭代器的remove方法。

HashSet日常操作

1.基本例子

package com.dylan.collection;

import java.util.HashSet;

/**
* @author xusucheng
* @create 2018-01-27
**/
public class HashSetExample {
public static void main(String args[]) {
// HashSet declaration
HashSet<String> hset =
new HashSet<String>(); // Adding elements to the HashSet
hset.add("Apple");
hset.add("Mango");
hset.add("Grapes");
hset.add("Orange");
hset.add("Fig");
//Addition of duplicate elements
hset.add("Apple");
hset.add("Mango");
//Addition of null values
hset.add(null);
hset.add(null); //Displaying HashSet elements
System.out.println(hset);
}
}

输出:

[null, Apple, Grapes, Fig, Mango, Orange]

2.删除所有元素

package com.dylan.collection;

import java.util.HashSet;

/**
* @author xusucheng
* @create 2018-01-27
**/
public class EmptyHashSetExample {
public static void main(String[] args) {
// Create a HashSet
HashSet<String> hset = new HashSet<String>(); //add elements to HashSet
hset.add("Element1");
hset.add("Element2");
hset.add("Element3");
hset.add("Element4");
hset.add("Element5"); // Display HashSet elements
System.out.println("Before: HashSet contains: "+ hset); /* public void clear(): It removes all the elements
* from HashSet. The set becomes empty after this
* method gets called.
*/
hset.clear(); // Display HashSet content again
System.out.println("After: HashSet contains: "+ hset);
}
}

输出:

Before: HashSet contains: [Element5, Element4, Element3, Element2, Element1]
After: HashSet contains: []

3.如何迭代

3.1 使用Iterator
3.2 使用for循环
package com.dylan.collection;

import java.util.HashSet;
import java.util.Iterator; /**
* @author xusucheng
* @create 2018-01-27
**/
public class IterateHashSet {
public static void main(String[] args) {
// Create a HashSet
HashSet<String> hset = new HashSet<String>(); //add elements to HashSet
hset.add("Chaitanya");
hset.add("Rahul");
hset.add("Tim");
hset.add("Rick");
hset.add("Harry");
//1.use Iterator
System.out.println("----use Iterator:");
Iterator<String> it = hset.iterator();
while(it.hasNext()){
System.out.println(it.next());
} //2.use loop
System.out.println("----use loop:");
for (String temp : hset) {
System.out.println(temp);
}
}
}

输出:

----use Iterator:
Chaitanya
Rahul
Harry
Tim
Rick
----use loop:
Chaitanya
Rahul
Harry
Tim
Rick

4.转换为数组

package com.dylan.collection;

import java.util.HashSet;

/**
* @author xusucheng
* @create 2018-01-27
**/
public class ConvertHashSettoArray {
public static void main(String[] args) {
// Create a HashSet
HashSet<String> hset = new HashSet<String>(); //add elements to HashSet
hset.add("Element1");
hset.add("Element2");
hset.add("Element3");
hset.add("Element4"); // Displaying HashSet elements
System.out.println("HashSet contains: "+ hset); // Creating an Array
String[] array = new String[hset.size()];
hset.toArray(array); // Displaying Array elements
System.out.println("Array elements: ");
for(String temp : array){
System.out.println(temp);
}
}
}

输出:

HashSet contains: [Element4, Element3, Element2, Element1]
Array elements:
Element4
Element3
Element2
Element1

5.转换为TreeSet

package com.dylan.collection;

import java.util.HashSet;
import java.util.Set;
import java.util.TreeSet; /**
* @author xusucheng
* @create 2018-01-27
**/
public class ConvertHashSettoTreeSet {
public static void main(String[] args) {
// Create a HashSet
HashSet<String> hset = new HashSet<String>(); //add elements to HashSet
hset.add("Element1");
hset.add("Element2");
hset.add("Element3");
hset.add("Element4"); // Displaying HashSet elements
System.out.println("HashSet contains: "+ hset); // Creating a TreeSet of HashSet elements
Set<String> tset = new TreeSet<String>(hset); // Displaying TreeSet elements
System.out.println("TreeSet contains: ");
for(String temp : tset){
System.out.println(temp);
}
}
}

输出:

HashSet contains: [Element4, Element3, Element2, Element1]
TreeSet contains:
Element1
Element2
Element3
Element4

6.转换为List/ArrayList

package com.dylan.collection;

import java.util.ArrayList;
import java.util.HashSet;
import java.util.List; /**
* @author xusucheng
* @create 2018-01-27
**/
public class ConvertHashSetToArrayList {
public static void main(String[] args) {
// Create a HashSet
HashSet<String> hset = new HashSet<String>(); //add elements to HashSet
hset.add("Steve");
hset.add("Matt");
hset.add("Govinda");
hset.add("John");
hset.add("Tommy"); // Displaying HashSet elements
System.out.println("HashSet contains: "+ hset); // Creating a List of HashSet elements
List<String> list = new ArrayList<String>(hset); // Displaying ArrayList elements
System.out.println("ArrayList contains: "+ list);
}
}

输出:

HashSet contains: [Matt, Steve, Govinda, John, Tommy]
ArrayList contains: [Matt, Steve, Govinda, John, Tommy]

HashSet 对比 HashMap

1.相同点

1)两者都是非线程安全的。

2)都不保证元素的顺序

3)如果你看了HashSet源码就知道它的背后是HashMap在支持其各种操作。

4)两者在添加,删除元素等操作时的性能一致。

2.不同点

HashSet HashMap
实现的是Set接口 实现的是Map接口
存储的是对象(元素或值),例如我有一个存储String元素的HashSet,
我可以这样描述:[null, Apple, Grapes, Fig, Mango, Orange]
存储的是Key&Value(键值对)
不允许有重复值 不允许有重复Key,但可以有多个重复value
只允许有一个null元素 允许有一个null key, null的value可以有多个

Java集合框架学习(二) HashSet详解的更多相关文章

  1. Hibernate框架学习(二)——api详解

    一.Configuration对象 功能:配置加载类,用于加载主配置,orm元数据加载. //1.创建,调用空参构造(还没有读配置文件) Configuration conf=new Configur ...

  2. Java集合框架学习(一)List

    先附一张Java集合框架图. 从上面的集合框架图可以看到,Java集合框架主要包括两种类型的容器,一种是集合(Collection),存储一个元素集合,另一种是图(Map),存储键/值对映射.Coll ...

  3. Java集合框架学习

    集合框架 集合框架的目标 该框架必须是高性能的.基本集合(动态数组,链表,树,哈希表)的实现必须是高效的. 该框架允许 不同类型的集合,以类似的方式工作,具有高度的互操作性. 对一个集合的扩展和适应必 ...

  4. java集合的方法及使用详解

    一.java集合的分类及相互之间的关系 Collection接口:向下提供了List和Set两个子接口 |------List接口:存储有序的,存储元素可以重复 |------ArrayList(主要 ...

  5. Java 集合Collection与List的详解

    1.什么是集合 存储对象的容器,面向对象语言对事物的体现都是以对象的形式,所以为了方便对多个对象的操作,存储对象,集合是存储对象最常用的一种方式. 集合的出现就是为了持有对象.集合中可以存储任意类型的 ...

  6. 【java基础 11】java集合框架学习

    导读:本篇博客主要是从整体上了解java的集合框架,然后主要介绍几个自己在项目中用到的结构,比如说:hashtable.hashmap.hashset.arraylist等! 一.宏观预览 从宏观上看 ...

  7. Java后端框架之Spring Boot详解,文末有Java分布式实战项目视频可取

    在 Java 后端框架繁荣的今天,Spring 框架无疑是最最火热,也是必不可少的开源框架,更是稳坐 Java 后端框架的龙头老大. 用过 Spring 框架的都知道 Spring 能流行是因为它的两 ...

  8. java集合框架(二):HashTable

    HashTable作为集合框架中的一员,现在是很少使用了,一般都是在面试中会问到其与HashMap的区别.为了能在求职的时候用上场,我们有必要对其原理进行解读. HashTable的实现原理跟Hash ...

  9. Java集合框架学习笔记

    集合类的由来:对象用于封装特有数据,对象多了需要存储,如果对象的长度不确定,就使用集合存储. 集合特点1.用于存储对象的容器.2.集合的长度可变.3.集合中不可以存储基本类型 集合容器因为内部的数据结 ...

  10. Java集合框架(二)

    原文  http://www.jianshu.com/p/2070cb32accb List接口 查阅API,看 List 的介绍.有序的 collection (也称为序列).此接口的用户可以对列表 ...

随机推荐

  1. 使用JavaStream将List转为Map

    有的时候博客内容会有变动,首发博客是最新的,其他博客地址可能会未同步,认准https://blog.zysicyj.top 首发博客地址 系列文章地址 使用Java Stream将List转换为Map ...

  2. [转帖]十分钟掌握 Vim 编辑器核心功能

    https://juejin.cn/post/6929248764746006535 前言 相信不论是前端还是后台多多少少都需要上到服务器上做一些操作,改改配置文件等,大多数 Linux 服务器默认都 ...

  3. [转帖]kingbase(人大金仓)的一些常用表操作语句

    包括 1)创建表 2)删除表 3)加字段 4)字段换名 5)字段改类型 6)字段添加注释 7)修改字段为自增类型 8)增加主键 9)查看模式下的表 一.创建和删除表 DROP TABLE IF EXI ...

  4. [转帖]【压测】通过Jemeter进行压力测试(超详细)

    文章目录 背景 一.前言 二.关于JMeter 三.准备工作 四.创建测试 4.1.创建线程组 4.2.配置元件 4.3.构造HTTP请求 4.4.添加HTTP请求头 4.5.添加断言 4.6.添加察 ...

  5. [转帖]【JVM】堆内存与栈内存详解

    堆和栈的定义 java把内存分成栈内存和堆内存. (1)栈内存 在函数中定义的一些基本类型的变量和对象的引用变量都是在函数的栈内存中分配. 当在一段代码块中定义一个变量时,java就在栈中为这个变量分 ...

  6. [转帖]JVM 问题诊断快速入门

    https://zhuanlan.zhihu.com/p/110197145 JVM 全称为 Java Virtual Machine,翻译为中文 "Java 虚拟机".本文中的J ...

  7. SpringBoot 连接Oracle 12c 以上版本PDB的解决思路

    1. 最近公司产品改用springboot开发, 要支持企业级大型数据库Oracle ,并且版本要求比较高,需要使用Oracle12c以上. 又因为Oracle 12c 以上有了一个PDB的可插拔数据 ...

  8. dmidecode 查看内存以及硬件信息

    安装工具dmidecode 使用 1.查看内存槽及内存条 $ sudo dmidecode -t memory 2.查看内存的插槽数,已经使用多少插槽.每条内存多大 $ sudo dmidecode  ...

  9. redis 6源码解析之 sds

    redis使用sds(simple dynamic string)实现了字符串的存储.sds实际上就是TLV格式的数据结构.其数据结构主要分为如下5种,主要分为首部和数据部分,首部给出了type和le ...

  10. vue混入mixin

    <div id="app"> --{{nick11}} </div> <script> // 全局混入 不需要注册 var m1 = Vue.m ...