前言

为什么集合在存自定义类型时需要重写equals和hashCode?

1、先说List集合

List集合在存数据时是可以重复的但是 当我们需要判断一个对象是否在集合中存在时这样就有问题了!

因为我们通常判断一个对象是否在集合中存在只需要判断值就行   而List内部实现方法是用地址来进行判断的  因为我们在创建对象时即使是值都一样

但是内存地址不一样 所以也就无法判定 一个对象是否在另一个对象中存在     我们可以在自定义类中重写equals方法 只是值相等就证明该对象在集合中存在

2、在说Set集合

Set集合在存自定义类型的数据时 为了要保证唯一性(set集合的特点:数据是不能重复的)我们要重写hashCode(执行效率高) 和 equals  内部就会自动判断

如果数据相等就不添加否则就添加到集合中

不管是利用Set集合的TreeSet  还是用Map集合的TreeMap  这二个数据类型的共同点都是  只存知道怎么排序的集合这是为什么,如果我们要想存自定义类型的数据该怎么办?

是因为上面二个集合在add的时候内部调用了基本数据类型的compareTo方法(内部排序是先比较后排序)  这些数据类型(例如String、Double)内部都已经重写了compareTo方法 所以可以自动排序

而我们在上面二个集合中添加自定义类型的数据时  会报错编译不通过(因为树形数据类型 是不存不知道怎么排序的集合的) 就是因为 自定义类型不知道按什么排序 是添加不到上面集合中去的 这个时候我们也需要重写compareTo  按我们自定义类型中的某个字段排序就可以了。

重写compareTo是第一种方法 下面来看下核心代码及视图:

public static void main(String[] args) {
// 利用自定义类型 为树形集合数据类型排序 // 1、java自带的数据类型 为什么可以自动排序呢?
// 因为add方法里调用了 compareTo java自带的数据类型都重写了 compareTo方法
// 2、自定义类型怎么实现自动排序?
// 根据1中的推理 我们也需要再自定义类中重写 compareTo方法 已到达按哪个字段排序的目的
// 因为树形数据类型 是不存不知道怎么排序的集合的 // 返回值为0:已存在
// 返回值为正:放到后
// 返回值为负:放到前 TreeSet<Student> tss = new TreeSet<Student>(); tss.add(new Student("b",9));
tss.add(new Student("f",8));
tss.add(new Student("a",20));
tss.add(new Student("c",19));
tss.add(new Student("b",18));
tss.add(new Student("b",18));
System.out.println(tss); }
public int compareTo(Student o) {
// TODO Auto-generated method stub
int res = this.age - o.age; // 假如年龄相等按照名称排序
if(res == 0){
String name1 = this.name;
String name2 = o.name;
return name1.compareTo(name2);
}else{
return res;
}
}

1、图中的compareTo为什么有参数?       比较需要二个对象进行比较 一个是之前的数据 this  一个是通过参数传进来的对象  也就是传统的A类调用B类

2、第二种:可以利用多态 将比较方法提取出来放到一个类中  然后将此类对象作为TreeSet的 成员属性  通过TreeSet的构造方法为成员属性赋值 如下图:

第二种方法的灵活性比较高可以按多种选择进行排序。实例代码:

//比较器类
public class Comp1 implements Comparator<Book> { @Override
public int compare(Book o1, Book o2) {
// TODO Auto-generated method stub
// 先按编号排序在按书名排序
int res = o1.getNum() - o2.getNum(); if(res == 0){
String name1 = o1.getName();
String name2 = o2.getName();
return name1.compareTo(name2);
}else{
return res;
}
} }
TreeSet<Book> ts = new TreeSet<Book>(new Comp1());
ts.add(new Book("葵花宝典", 2));
ts.add(new Book("九阴真经",1));
System.out.println(ts);

总结:正负决定排序规则

树形结构如何保证数据唯一性?

1、HashSet和LinkedHashSet 我们自定义类需要重写hashCode和equals方法

2、TreeSet 自定义类时需要重写compareTo方法

3、TreeSet 自定义类时可以创建比较器类

集合排序总结:

1、List集合 可以自己写排序 (冒泡或者选择)

2、Set集合

1)hashSet和LinkedHashSet   无法排序

  2)TreeSet 自然排序 和自定义类型排序(可以利用compareTo和编写比较器来进行排序)【目的只是为了能够存自定义类型的数据】

3、Map集合同Set集合一样

4、Collections工具类中一些方法的操作只针对List集合(不针对没有下标的集合)

java利用自定义类型对树形数据类型进行排序的更多相关文章

  1. Hadoop MapReduce编程 API入门系列之自定义多种输入格式数据类型和排序多种输出格式(十一)

    推荐 MapReduce分析明星微博数据 http://git.oschina.net/ljc520313/codeexample/tree/master/bigdata/hadoop/mapredu ...

  2. Java利用自定义注解、反射实现简单BaseDao

    在常见的ORM框架中,大都提供了使用注解方式来实现entity与数据库的映射,这里简单地使用自定义注解与反射来生成可执行的sql语句. 这是整体的目录结构,本来是为复习注解建立的项目^.^ 好的,首先 ...

  3. java MVC 自定义类型转换器(Formatter、AnnotationFormatterFactory)

    下面一个事例,是将传入的一个身份证号,转换成一个对象(提取身份证号的地址.出身日期.性别等) 实体类 Person 有三个字段如下: String province; //地址 Date birthd ...

  4. java@ 利用ArrayList实现dijkstra算法以及topological 排序算法(java.util.ArrayList)

    package dataStructure; import java.util.ArrayList; import java.util.LinkedList; import java.util.Que ...

  5. [原创]java WEB学习笔记67:Struts2 学习之路-- 类型转换概述, 类型转换错误修改,如何自定义类型转换器

    本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱 ...

  6. java编程排序之自定义类型的集合,按业务需求排序

    自定义引用类型放入集合中,按实际业务需求进行排序的两种思路 第一种思路: (1)自定义实体类实现java.lang.Comparable接口,重写public int compareTo(Object ...

  7. java 编程基础:【注解】 提取注解信息,利用自定义注解编写测试类,注解绑定事件

    提取注解信息 使用注解修饰了类.方法.成员变量等成员之后,这些注解不会自己生效,必须由开发者提供相应工具来提取并处理注解信息.   Java使用java.lang.annotation.Annotat ...

  8. 2016年11月3日JS脚本简介数据类型: 1.整型:int 2.小数类型: float(单精度) double(双精度) decimal () 3.字符类型: chr 4.字符串类型:sting 5.日期时间:datetime 6.布尔型数据:bool 7.对象类型:object 8.二进制:binary 语言类型: 1.强类型语言:c++ c c# java 2.弱类型语

    数据类型: 1.整型:int 2.小数类型: float(单精度) double(双精度) decimal () 3.字符类型: chr 4.字符串类型:sting 5.日期时间:datetime 6 ...

  9. java利用反射获取类的属性及类型

    java利用反射获取类的属性及类型. import java.lang.reflect.Field; import java.math.BigDecimal; import java.util.Map ...

随机推荐

  1. mysql导出与导入

    环境 centos6.5 32位 Mysql 5.7.19 导出 mysqldump用法 导出整个数据库 [root@mini2 mysql]# mysqldump -p123456 --databa ...

  2. Ajax.html:35 [Deprecation] Synchronous XMLHttpRequest on the main thread is deprecated because of its detrimental effects to the end user's experience. For more help, check https://xhr.spec.whatwg.org

    AJAX的容易错误的地方 Ajax.html:35 [Deprecation] Synchronous XMLHttpRequest on the main thread is deprecated ...

  3. 个人网站建设(适合Java初学者)(一)

    概述 作为一个在八本学校在校生,没有实验室,也没有项目可做.一直想做一个个人博客,一年前学完javaweb之后做了一个简单的博客,ui惨不忍睹就算了,还有各种bug.酝酿了很久,寒假用了将近一个月时间 ...

  4. POJ-2349 Arctic Network---MST的第m长的边

    题目链接: https://vjudge.net/problem/POJ-2349 题目大意: 要在n个节点之间建立通信网络,其中m个节点可以用卫星直接连接,剩下的节点都要用线路连接,求剩下这些线路中 ...

  5. linux samba服务配置

    1.下载 wget+rpm或yum install 2.配置/etc/samba/smb.conf cat smb.conf | grep setsebool 执行终端打印出来的字符串 setsebo ...

  6. 前端面试送命题-JS三座大山

    前言 本篇文章比较适合3年以上的前端工作者,JS三座大山分别指:原型与原型链,作用域及闭包,异步和单线程. 原型与原型链 说到原型,就不得不提一下构造函数,首先我们看下面一个简单的例子: functi ...

  7. Python模块 - configparser

    configparser模块用来对配置文件进行操作 1.获取所有块 import configparser config = configparser.ConfigParser() config.re ...

  8. spring初学总结思路

    spring初步学习总结 总概括有四个方面:IOC,AOP,JDBC,和事务管理 ioc:实现了new类的一个权力的反转.(平时new类导致代码冗余,手动new类无法满足动态new类的需求) aop: ...

  9. 【Swfit】Swift与OC两种语法写单例的区别

    Swift与OC两种语法写单例的区别 例如写一个NetworkTools的单例 (1)OC写单例 + (instancetype)sharedNetworkTools { static id inst ...

  10. 洛谷3794 签到题IV

    题目描述 给定一个长度为n的序列$a_1,a_2...a_n$,其中每个数都是正整数. 你需要找出有多少对(i,j),$1 \leq i \leq j \leq n$且$gcd(a_i,a_{i+1} ...