集合分类:
-------------------| Collection 单列集合的根接口   
---------------| List 如果实现了List接口的集合类,具备的特点是:有序,可重复
-----------| ArrayList ArrayList底层维护的是一个Object类型的数组,特点是:查询快,增删慢
使用场景:如果目前的数据查询多,增删少,那么就使用ArrayList存储数据
注意:使用ArrayList无参构造方法时,Object默认的长度时10,不够的话自动增长0.5倍
-----------| LinkedList LinkedList底层使用了链表数据结构实现的。特点是:查询慢,增删快
使用场景:数据查询少,增删多的时候,用LinkedList存储

---------------| Set 如果实现了Set接口的集合类,具备的特点是:无序,不可重复
注意:Set接口没有get()方法,迭代器才是通用遍历集合的方法,所以我们最好使用迭代器遍历
-----------| HashSet

HashSet的实现原理:
    往HashSet添加元素的时候,HashSet会自动先调用元素的hashCode方法得到元素的哈希表,然后通过元素的哈希值经过移位等运算,就可以算出该元素在哈希表中的存储位置
    
    情况一:如果算出元素的存储位置目前还没有元素,那么该元素可以直接存储到该位置
    
    情况二:如果算出元素的存储位置已经存在其他元素,那么会自动调用equals方法再进行比较一次如果equals返回ture那么就视为重复元素,不可添加,如果返回false,那么就可以添加
    
    注意:hashCode和equals方法,都是自动调用的,并不是我们手动调用(注意List接口和Set实现原理不同之处)
    
-----------| ThreeSet

ThreeSet注意事项:
    1.ThreeSet在添加元素的时候,如果数据有自然排序规则,那么就按照元素的自然顺序的特性进行排序存储
    2.ThreeSet在添加元素的时候,如果数据不具备自然排序规则,那么该元素所属类必须实现Comparable接口,把元素的比较规则写在compareTo方法上
    3.ThreeSet在添加元素的时候,如果元素本身不具备自然数据特性,而元素也没有实现Comparable接口,那么必须要在创建ThreeSet的时候传入一个比较器
    4.如果比较元素的时候调用compareTo返回的是0,那么该元素就被视为重复元素,不可添加(注意:跟hashcode和equals无关)

自然特性:

    例如 数字 字母等,因为它们都实现了Comparable接口,不需要我们再自己定义排序规则了

字符串比较规则:

    情况一:对应位置有不同字符出现,那么就比较的就是对应位置的字符

    情况二:对应位置有相同的字符出现,那么比较的是字符的长度

比较器定义规则:
    自定义一个类,实现Comparable接口,把比较规则写在compareTo方法中

注意:ThreeSet是在排好序再进行存储的,并不是在输出的时候再排序输出的

推荐使用:比较器,这样提高了代码的重用性

ThreeSet的存储原理:
    底层是使用红黑数(二叉树)数据结构实现的     储存规则:左小右大

首先第一个是老钟,因为没有比较的对象,所以老钟排在最顶端

第二是老陆先跟老钟比,比老钟小,所以排在老钟的左边

第三是老汤先跟老钟比,比老钟大,所以排在老钟的右边

第二是老黎先跟老钟比,比老钟大,所以排在老钟的右边,再跟老汤比比老汤大所以在老汤的右边

最后的结果是:老陆 老钟  老汤  老黎

注意:如果三个数据还没有构成二叉树数据结构,那么就会自动调增为二叉树数据结构

也就是:

  先添加老陆后添加老钟那么老钟在老陆右边

  再添加老汤,老汤比老陆和老钟都大,再老钟右边

  这时就是没有构成二叉树数据结构,那么它会自动调增为

  老钟在最上面,老陆在左边,老汤在右边

不具备自然规则的实例:

class People {
int id;
String name; public People(int id , String name) {
this.id = id;
this.name = name;
}
@Override
public String toString() { return "{ 身份证"+this.id+" 姓名:"+this.name+" }";
}
} class PeopleComparator implements Comparator{ @Override
public int compare(Object o1, Object o2) {
People p1 = (People)o1;
People p2 = (People)o2;
return p1.id-p2.id;
} }
public class Demo2 {
public static void main(String[] args) {
PeopleComparator peocom = new PeopleComparator();
TreeSet set = new TreeSet(peocom);
set.add(new People(1003,"狗蛋"));
set.add(new People(1001,"狗娃"));
set.add(new People(1002,"老李"));
//添加一个身份证一样的,姓名不一样的人
set.add(new People(1001,"老八"));
//使用迭代器遍历
Iterator it = set.iterator();
while(it.hasNext()) {
System.out.println(it.next());
}
} }

具备规则的实例:

public class Demo2 {
public static void main(String[] args) {
TreeSet set = new TreeSet();
set.add(10);
set.add(5);
set.add(9);
TreeSet set1 = new TreeSet();
set1.add("b");
set1.add("c");
set1.add("a");
//使用迭代器遍历
Iterator it = set.iterator();
while(it.hasNext()) {
System.out.print(it.next()+",");
}
System.out.println(" ");
Iterator it1 = set1.iterator();
while(it1.hasNext()) {
System.out.print(it1.next());
}
}
}

51. TreeSet的更多相关文章

  1. Spring Boot文档

    本文来自于springboot官方文档 地址:https://docs.spring.io/spring-boot/docs/current/reference/html/ Spring Boot参考 ...

  2. Java 集合类 TreeSet、TreeMap

    TreeMap和TreeSet的异同: 相同点: TreeMap和TreeSet都是有序的集合,也就是说他们存储的值都是拍好序的. TreeMap和TreeSet都是非同步集合,因此他们不能在多线程之 ...

  3. Java 容器 & 泛型:三、HashSet,TreeSet 和 LinkedHashSet比较

    Writer:BYSocket(泥沙砖瓦浆木匠) 微博:BYSocket 豆瓣:BYSocket 上一篇总结了下ArrayList .LinkedList和Vector比较,今天泥瓦匠总结下Hash ...

  4. Java集合--TreeSet

    转载请注明出处:http://www.cnblogs.com/skywang12345/admin/EditPosts.aspx?postid=3311268 第1部分 TreeSet介绍 TreeS ...

  5. TreeSet源码解析笔记

    定义: TreeSet是一个有序的集合,它的作用是提供有序的Set集合.它继承了AbstractSet抽象类,实现了NavigableSet<E>,Cloneable,Serializab ...

  6. Java中TreeSet的详细用法

    第1部分 TreeSet介绍 TreeSet简介 TreeSet 是一个有序的集合,它的作用是提供有序的Set集合.它继承于AbstractSet抽象类,实现了NavigableSet, Clonea ...

  7. 集合框架-TreeSet集合-二叉树

    1 package cn.itcast.p5.treeset.demo; 2 3 import java.util.Iterator; 4 import java.util.TreeSet; 5 6 ...

  8. 集合框架-TreeSet集合

    1 package cn.itcast.p5.treeset.demo; 2 3 import java.util.Iterator; 4 import java.util.TreeSet; 5 6 ...

  9. HashSet HashTable 与 TreeSet

    HashSet<T>类 HashSet<T>类主要是设计用来做高性能集运算的,例如对两个集合求交集.并集.差集等.集合中包含一组不重复出现且无特性顺序的元素. HashSet& ...

随机推荐

  1. LeetCode Array Easy 88. Merge Sorted Array

    Description Given two sorted integer arrays nums1 and nums2, merge nums2 into nums1 as one sorted ar ...

  2. Elasticsearch添加Shield后TransportClient如何连接?

    Elasticsearch添加Shield后TransportClient如何连接? 时间 2015-12-28 10:24:01  旁门左道 原文  http://log.medcl.net/ite ...

  3. linux常用命令记录(一)

    文件搜索命令 grep在文件中查找字符并输出 grep 字符或字符串 文件目录 grep pub /teach/.txt -c 字符出现总行数 grep .txt -n 行号 grep .txt -i ...

  4. qdatatime大小

    QDateTime time1; QDateTime time2; uint stime = time1.toTime_t(); uint etime = time2.toTime_t(); int ...

  5. java输入一个整数N,打印1~n位数

    举个栗子:输入 3 : 打印1,2,3......999 这里要注意一个坑,不可以直接算出最大的数,然后从1开始打印 .因为当n足够大时,n位数必定会超出int范围和long范围 所以我们需要用字符串 ...

  6. asp.net core Mvc 增删改查

    1.创建项目 创建Data文件夹 创建实体类Students/cs public class Students { public Guid Id { get; set; } public string ...

  7. Ubuntu开放对外端口

    1.查看已经开启的端口 sudo ufw status 2.打开80端口 sudo ufw allow 80 3.防火墙开启 sudo ufw enable 4.防火墙重启 sudo ufw relo ...

  8. linux文件目录颜色及特殊权限对应的颜色

    白色:表示普通文件蓝色:表示目录绿色:表示可执行文件红色:表示压缩文件浅蓝色:链接文件红色闪烁:表示链接的文件有问题黄色:表示设备文件灰色:表示其它文件 各种背景颜色的显示和文件的权限有关红色背景:特 ...

  9. ASP.NET Core学习——2

    Application Startup ASP.NET Core为应用程序提供了处理每个请求的完整控制.Startup类是应用程程的入口(entry point),这个类可以设置配置(configur ...

  10. 不带头结点的单链表------C语言实现

    File name:no_head_link.c Author:SimonKly Version:0.1 Date: 2017.5.20 Description:不带头节点的单链表 Funcion L ...