1.Set接口概述

       Set 不保存重复的元素(如何判断元素相同呢?)。如果你试图将相同对象的多个实例添加到Set中,那么它就会阻止这种重复现象。 Set中最常被使用的是测试归属性,你可以很容易地询问某个对象是否在某个Set中。 正因如此,查找就成为了Set中最重要的操作,因此你通常都会选择一个HashSet 的实现,它专门对快速查找进行了优化。

Set具有与Collection完全一样的接口,因此没有任何额外的功能,不像前面的List。实际上Set就是Collection,只是行为不同。(这是继承与多态思想的典型应用:表现不同的行为)。Set 是基于对象的值来确定归属性的。

java.util Interface Set<E>

参数类型 E  : 由此集合维护的元素的类型
所有超类接口:Collection <E>, Iterable <E>
所有子类接口:NavigableSet <E>, SortedSet <E>

所有已知实现类: AbstractSetConcurrentHashMap.KeySetViewConcurrentSkipListSetCopyOnWriteArraySetEnumSet ,  HashSetJobStateReasonsLinkedHashSetTreeSet


2.Set常用实现类

(1)HashSet

HashSet继承AbstractSet类,实现Set、Cloneable、Serializable接口。由哈希表支持(实际上是一个HashMap实例,基于

HashMap来实现的,底层采用HashMap来保存元素。),天生就是为了提高查找效率的。

                

构造方法

所有方法

(2)TreeSet

TreeSet 继承AbstractSet类,实现NavigableSet、Cloneable、Serializable接口。与HashSet是基于HashMap实现一样,TreeSet 同样是基于TreeMap 实现的。由于得到Tree 的支持,TreeSet 最大特点在于排序,它的作用是提供有序的Set集合。

参数类型
      E - 由此集合维护的元素的类型
All Implemented Interfaces(实现接口):
     SerializableCloneableIterable <E>,Collection <E>,NavigableSet <E>
    Set <E>  SortedSet <E>

构造方法

常用方法

(3)LinkedHashSet

      LinkedHashSet 综合了链表+哈希表,根据元素的hashCode值来决定元素的存储位置,它同时使用链表维护元素的次序。

当遍历该集合时候,LinkedHashSet 将会以元素的添加顺序访问集合的元素。

对于 LinkedHashSet 而言,它继承与 HashSet、又基于 LinkedHashMap 来实现的。

public class LinkedHashSet<E> extends

HashSet<E> implements Set<E>,Cloneable,Serializable

参数类型E ---由此集合维护的元素的类型
All Implemented Interfaces(实现接口):
SerializableCloneableIterable <E>, Collection <E>, Set <E>              

构造方法

方法(基本都是继承方法)

3.set演示

(1)HashSet

 public class HashSetDemo {

 	/**
 	 * @param args
 	 */
 	public static void main(String[] args) {

 		//1,创建一个Set容器对象。
 		Set set = new HashSet();//如果该成LinkedHashSet,可实现有序。

 		//2,添加元素。
 		set.add("abc");
 		set.add("nba");
 		set.add("heihei");
 		set.add("haha");
 		set.add("heihei");

 		//3,只能用迭代器取出。
 		for (Iterator it = set.iterator(); it.hasNext();) {
 			System.out.println(it.next());
 		}

 	}

 }
 

(2)TreeSet

 public class TreeSetDemo2 {

 	/**
 	 * @param args
 	 */
 	public static void main(String[] args) {

 		//初始化TreeSet集合明确一个比较器。
 		Set set = new TreeSet(new ComparatorByName());

 		set.add(new Student("xiaoqiang",20));
 		set.add(new Student("daniu",24));
 		set.add(new Student("xiaoming",22));
 		set.add(new Student("tudou",18));
 		set.add(new Student("daming",22));
 		set.add(new Student("dahuang",19));

 		for (Iterator it = set.iterator(); it.hasNext();) {
 			Student stu = (Student)it.next();
 			System.out.println(stu.getName()+"::"+stu.getAge());
 		}
 	}

 }
 /**/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
  * 自定义一个比较器,用来对学生对象按照姓名进行排序。
  * @author Administrator
  *
  */
 public class ComparatorByName extends Object implements Comparator {

 	@Override
 	public int compare(Object o1, Object o2) {

 		Student s1 = (Student)o1;
 		Student s2 = (Student)o2;

 		int temp = s1.getName().compareTo(s2.getName());

 		return temp==0?s1.getAge()-s2.getAge():temp;
 	}

 }
 /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
 public class Student implements Comparable {

 	private String name;
 	private int age;

 	public Student() {
 		super();

 	}
 	public Student(String name, int age) {
 		super();
 		this.name = name;
 		this.age = age;
 	}

 	/**
 	 *  覆盖hashCode方法。根据对象自身的特点定义哈希值。
 	 */
 	public int hashCode(){
 		final int NUMBER = 37;
 		return name.hashCode() + age*NUMBER;
 	}

 	/**
 	 * 需要定义对象自身判断内容相同的依据。覆盖equals方法。
 	 *
 	 */
 	public boolean equals(Object obj){

 		if(this == obj){
 			return true;
 		}

 		if(!(obj instanceof Student)){
 			throw new ClassCastException("类型错误");
 		}

 		Student stu = (Student)obj;

 		return this.name.equals(stu.name)&& this.age == stu.age;
 	}

 	public String getName() {
 		return name;
 	}
 	public void setName(String name) {
 		this.name = name;
 	}
 	public int getAge() {
 		return age;
 	}
 	public void setAge(int age) {
 		this.age = age;
 	}
 	@Override
 	public String toString() {
 		return "Student [name=" + name + ", age=" + age + "]";
 	}
 	/**
 	 * 学生就具备了比较功能。该功能是自然排序使用的方法。
 	 * 自然排序就年龄的升序排序为主。
 	 */
 	@Override
 	public int compareTo(Object o) {

 		Student stu = (Student)o;
 //		System.out.println(this.name+":"+this.age+"........"+stu.name+":"+stu.age);
 		/*
 		if(this.age>stu.age)
 			return 1;
 		if(this.age<stu.age)
 			return -1;
 		return 0;
 		*/

 		/*
 		 * 既然是同姓名同年龄是同一个人,视为重复元素,要判断的要素有两个。
 		 * 既然是按照年龄进行排序。所以先判断年龄。在判断姓名。
 		 */
 		int temp = this.age - stu.age;

 		return temp==0?this.name.compareTo(stu.name):temp;

 	}

 }
 

2018-01-05

内容来自API1.8、Java编程思想、传智播客课程

Java容器---Set: HashSet & TreeSet & LinkedHashSet的更多相关文章

  1. Set集合[HashSet,TreeSet,LinkedHashSet],Map集合[HashMap,HashTable,TreeMap]

    ------------ Set ------------------- 有序: 根据添加元素顺序判定, 如果输出的结果和添加元素顺序是一样 无序: 根据添加元素顺序判定,如果输出的结果和添加元素的顺 ...

  2. Leetcode: LFU Cache && Summary of various Sets: HashSet, TreeSet, LinkedHashSet

    Design and implement a data structure for Least Frequently Used (LFU) cache. It should support the f ...

  3. Java集合之HashSet/TreeSet原理

    Set集合 1.HashSet  只去重复, 没有顺序  HashSet的add方法会调用hashCode和equals, 所以存储在HashSet中的对象需要重写这两个方法. 2.TreeSet   ...

  4. java容器---集合总结

    思考为什么要引入容器这个概念? Java有多种方式保存对象(应该是对象的引用),例如使用数组时保存一组对象中的最有效的方式,如果你想保存一组基本类型的数据,也推荐使用这种方式,但大家知道数组是具有固定 ...

  5. 复习java基础第三天(集合:Collection、Set、HashSet、LinkedHashSet、TreeSet)

    一.Collection常用的方法: Java 集合可分为 Set.List 和 Map 三种体系: Set:无序.不可重复的集合. List:有序,可重复的集合. Map:具有映射关系的集合. Co ...

  6. Java集合框架(二)—— HashSet、LinkedHashSet、TreeSet和EnumSet

    Set接口 前面已经简绍过Set集合,它类似于一个罐子,一旦把对象'丢进'Set集合,集合里多个对象之间没有明显的顺序.Set集合与Collection基本上完全一样,它没有提供任何额外的方法. Se ...

  7. Java集合系列(三):HashSet、LinkedHashSet、TreeSet的使用方法及区别

    本篇博客主要讲解Set接口的三个实现类HashSet.LinkedHashSet.TreeSet的使用方法以及三者之间的区别. 注意:本文中代码使用的JDK版本为1.8.0_191 1. HashSe ...

  8. Java中的集合HashSet、LinkedHashSet、TreeSet和EnumSet(二)

    Set接口 前面已经简绍过Set集合,它类似于一个罐子,一旦把对象'丢进'Set集合,集合里多个对象之间没有明显的顺序.Set集合于Collection基本上完全一样,它没有提供任何额外的方法. Se ...

  9. Java自学-集合框架 HashSet、LinkedHashSet、TreeSet之间的区别

    HashSet. LinkedHashSet.TreeSet之间的区别 步骤 1 : HashSet LinkedHashSet TreeSet HashSet: 无序 LinkedHashSet: ...

随机推荐

  1. linux命令总结sed命令详解

    Sed 简介 sed 是一种新型的,非交互式的编辑器.它能执行与编辑器 vi 和 ex 相同的编辑任务.sed 编辑器没有提供交互式使用方式,使用者只能在命令行输入编辑命令.指定文件名,然后在屏幕上查 ...

  2. 在MySQL或者SQLServer中,添加对象后自动返回主键到对象模型中的配置方式

    设置是否使用JDBC的getGenereatedKeys方法获取主键并赋值到keyProperty设置的领域模型属性中.MySQL和SQLServer执行auto-generated key fiel ...

  3. 遗传算法入门C1

    遗传算法入门C1 觉得有用的话,欢迎一起讨论相互学习~Follow Me 参考文献 遗传算法历史 遗传算法(GA)是从生物进化的角度考虑提出来的方法,19世纪达尔文在大量观察基础上总结了大自然进化规律 ...

  4. tips 前端 bootstrap 嵌套行 嵌套列 溢出 宽度不正确 栅格化系统计算

    bootstrap 当嵌套列时 有时会出现很奇异的row 的width不对问题出现的情况时 <div class="row" > <!--row a--> ...

  5. Java并发编程原理与实战二十八:信号量Semaphore

    1.Semaphore简介 Semaphore,是JDK1.5的java.util.concurrent并发包中提供的一个并发工具类. 所谓Semaphore即 信号量 的意思. 这个叫法并不能很好地 ...

  6. SpringCloud(六) Hystrix入门

    前提 一个可用的Eureka注册中心(文中以之前博客中双节点注册中心,不重要) 一个连接到这个注册中心的服务提供者 快速入门 项目搭建 搭建一个新maven项目,artifactid为Ribbon-c ...

  7. 【mybatis笔记】 resultType与resultMap的区别

    序言: 昨天做一个项目,看到很多刚开始用mybatis的同事对于resultType和resultMap的理解与使用含糊不清,这里我试图用最好理解的说法写一写,欢迎大家勘误. 两者异同: 相同点:re ...

  8. golang sql.DB

    数据库 sql.DB连接池需知: sql.DB内置连接池,连接不足时会自动创建新连接,新创建的连接使用sql.Open()时传入的dsn来构造. sql.DBClose时只会关闭连接池中的连接,未归还 ...

  9. linux学习记录.4.常用命令

    帮助command --help    获取‘command‘命令的帮助 目录与文件 cd /home    进入‘home’目录 cd ..    返回上一级目录 cd       进入个人目录 c ...

  10. php中global和$GLOBALS最浅显易懂的解释

    官方文档: global指对变量的引用或者叫指针,$GLOBALS则是变量本身: $var1 = 1; $var2 = 2; function fun(){ $GLOBALS['var2'] = &a ...