前言

为什么集合在存自定义类型时需要重写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. Spring Security入门(1-9)Spring Security 的xml 命名空间配置

  2. Linux网络配置(仅主机模式)

    1.启动虚机,网络选择:仅主机模式 2.命令行输入 rm -rf /etc/udev/rules.d/70-persistent-net.rules 3.修改虚机中的网络配置 >>vim ...

  3. powerdesigner将name的名字赋给comment

    1 PowerDesigner中批量根据对象的name生成comment的脚本 执行方法:Open PDM -- Tools -- Execute Commands -- Run Script Vb ...

  4. python3全栈开发-面向对象、面向过程

    一. 什么是面向对象的程序设计及为什么要有它 1.面向过程 面向过程的程序设计:核心是过程二字,过程指的是解决问题的步骤,即先干什么再干什么......面向过程的设计就好比精心设计好一条流水线,是一种 ...

  5. html的基本结构

    html的基本结构 1.<html>内容</html> html文档的文档标记,也称为html开始标记 这对标记分别位于网页的最前端和最后端,表示开始和结束 2.<hea ...

  6. 浮动和BFC的学习整理转述

    前言:这是笔者学习之后自己的理解与整理.如果有错误或者疑问的地方,请大家指正,我会持续更新! 文档流的概念:html中block块元素默认是单独占据一行的,从上到下排列,也就是我们说的文档流; 脱离文 ...

  7. APP的宣传方式有哪些

    APP应用已经成为了互联网不可缺少的话题,事实上,开发一款移动APP的成本不是很高,但是怎样以最低的成本得到最大的推广效果,这是企业和开发者都很关心的一个问题.下面,我们来探讨一下这个问题. 1.一款 ...

  8. [LeetCode] Partition Labels 分割标签

    A string S of lowercase letters is given. We want to partition this string into as many parts as pos ...

  9. [SDOI 2011]黑白棋

    Description 题库链接 给出一个 \(1\times n\) 的棋盘,棋盘上有 \(k\) 个棋子,一半是黑色,一半是白色.最左边是白色棋子,最右边是黑色棋子,相邻的棋子颜色不同. 小 \( ...

  10. [SCOI 2010]传送带

    Description 题库链接 在一个 \(2\) 维平面上有两条传送带,每一条传送带可以看成是一条线段.两条传送带分别为线段 \(AB\) 和线段 \(CD\) .在 \(AB\) 上的移动速度为 ...