文档章节

Comparable与Comparator

c
 cpf2016
发布于 2016/08/25 20:29
字数 339
阅读 2
收藏 0
点赞 0
评论 0

(1)说明

                不管使用Comparator还是Comparable,在做比较的方法中:0表示相等,小于0表示排在前面,大于0表示排在后面(所以前面加上负号就可以逆序)

 

(2)Comparator(推荐使用)

           1.比较的类定义

                   可以看出没有任何处理

class Student{
	private long id;
	
	private String name;

	public long getId() {
		return id;
	}

	public void setId(long id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public Student(long id, String name) {
		super();
		this.id = id;
		this.name = name;
	}
}

           2.排序及测试

	@Test
	public void test() {
		List<Student> list = new ArrayList<Student>();
		
		Student student1 = new Student(1L, "ny");
		Student student2 = new Student(2L, "syx");
		Student student3 = new Student(3L, "ll");
		
		list.add(student1);
		list.add(student2);
		list.add(student3);
		
		Collections.sort(list, new Comparator<Student>() {
			@Override
			public int compare(Student o1, Student o2) {
				return (int) (o1.getId()-o2.getId());
			}
		});
		
		for (Student student : list) {
			System.out.println("id is "+student.getId()+";name is "+student.getName());
		}
	}

 

(3)Comparable

           1.比较的类定义

                   需要实现Comparable接口

class Student implements Comparable<Student>{
	private long id;
	
	private String name;

	public long getId() {
		return id;
	}

	public void setId(long id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public Student(long id, String name) {
		super();
		this.id = id;
		this.name = name;
	}

	@Override
	public int compareTo(Student o) {
		return (int) (this.id-o.getId());
	}
}

           2.排序及测试

	@Test
	public void testComparable() {
		List<Student> list = new ArrayList<Student>();

		Student student1 = new Student(1L, "ny");
		Student student3 = new Student(3L, "ll");
		Student student2 = new Student(2L, "syx");

		list.add(student1);
		list.add(student2);
		list.add(student3);

		Collections.sort(list);

		for (Student student : list) {
			System.out.println("id is " + student.getId() + ";name is "
					+ student.getName());
		}
	}

            结果为:

id is 1;name is ny
id is 2;name is syx
id is 3;name is ll
 

 

© 著作权归作者所有

共有 人打赏支持
c
粉丝 2
博文 5
码字总数 150099
作品 0
杭州
后端工程师
Java 中 Comparable 和 Comparator 比较

本文,先介绍Comparable 和Comparator两个接口,以及它们的差异;接着,通过示例,对它们的使用方法进行说明。 Comparable 简介 Comparable 是排序接口。 若一个类实现了Comparable接口,就意...

foxeye ⋅ 2016/03/01 ⋅ 0

Comparable与Comparator的区别

前几天在项目中遇到了一个将复杂对象进行排序的问题:计算BingMap地图上距离当前位置5KM内发生事故(TrafficIncident)的点到当前位置的距离,并按距离升序排序。距离都算出来了,但这些Tra...

摆渡者 ⋅ 2014/04/12 ⋅ 0

Comparable 和 Comparator 的区别

Java 中为我们提供了两种比较机制:Comparable 和 Comparator,他们之间有什么区别呢?今天来了解一下。 Comparable 自然排序 Comparable 在 java.lang 包下,是一个接口,内部只有一个方法 ...

Adel ⋅ 2016/12/13 ⋅ 0

java底层比较器Comparable和Comparator比较对象时的使用

刚开始学习java时可能对这2个接口存在一定的疑惑,对于Comparable意思是说:可以与此对象进行比较的那些对象的类型, 此接口强行对实现它的每个类的对象进行整体排序。这种排序被称为类的自然...

strict_nerd ⋅ 2015/05/22 ⋅ 0

重新认识TreeMap

特点 类不仅实现了接口,还实现了接口的子接口。由类实现的集合,不允许键对象为。 核心 1. 红黑树2. 比较器实现大小比较。 红黑树 一种平衡二叉树的实现。 比较器 由于需要排序,所以需要一个...

hgfgoodcreate ⋅ 2016/03/09 ⋅ 0

Java学习资料-Comparable和Comparator实现对象比较

当需要排序的集合或数组不是单纯的数字型时,通常可以使用Comparator或Comparable,以简单的方式实现对象排序或自定义排序。下面通过两个例子分别用Comparable和Comparator实现对User对象中年...

晓阳 ⋅ 2015/01/22 ⋅ 0

Comparable接口的实现和使用

1.什么是Comparable接口 此接口强行对实现它的每个类的对象进行整体排序。此排序被称为该类的自然排序 ,类的 compareTo 方法被称为它的自然比较方法 。实现此接口的对象列表(和数组)可以通...

executor ⋅ 2014/10/31 ⋅ 0

Java 排序之 Comparable 与 Comparator

1、Collections.sort() 为何 ClassCastException? 在收集物件之後,對物件進行排序是常用的動作,你不用親自實作排序演算法,提供有方法,由於必須有索引才能進行排序,因此的方法接受實作物...

xrzs ⋅ 2015/07/18 ⋅ 0

(java)总结TreeSet排序问题,其他的集合框架也如此

java中接口Set有众多实现类,而HashSet和TreeSet是最常用的两个,这里总结TreeSet实现排序的2种方式: 1.通过TreeSet(Comparator<? super E> comparator) 构造方法指定TreeSet的比较器进行排...

executor ⋅ 2014/12/13 ⋅ 0

Comparator和Comparable在排序中的应用

当需要排序的集合或数组不是单纯的数字型时,通常可以使用Comparator或Comparable,以简单的方式实现对象排序或自定义排序。 一、Comparator 强行对某个对象collection进行整体排序的比较函数...

stefanliao ⋅ 2012/05/29 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

OSChina 周日乱弹 —— 这么好的姑娘都不要了啊

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @TigaPile :分享曾惜的单曲《讲真的》 《讲真的》- 曾惜 手机党少年们想听歌,请使劲儿戳(这里) @首席搬砖工程师 :怎样约女孩子出来吃饭,...

小小编辑 ⋅ 28分钟前 ⋅ 1

Jenkins实践3 之脚本

#!/bin/sh# export PROJ_PATH=项目路径# export TOMCAT_PATH=tomcat路径killTomcat(){pid=`ps -ef | grep tomcat | grep java|awk '{print $2}'`echo "tom...

晨猫 ⋅ 今天 ⋅ 0

Spring Bean的生命周期

前言 Spring Bean 的生命周期在整个 Spring 中占有很重要的位置,掌握这些可以加深对 Spring 的理解。 首先看下生命周期图: 再谈生命周期之前有一点需要先明确: Spring 只帮我们管理单例模...

素雷 ⋅ 今天 ⋅ 0

zblog2.3版本的asp系统是否可以超越卢松松博客的流量[图]

最近访问zblog官网,发现zlbog-asp2.3版本已经进入测试阶段了,虽然正式版还没有发布,想必也不久了。那么作为aps纵横江湖十多年的今天,blog2.2版本应该已经成熟了,为什么还要发布这个2.3...

原创小博客 ⋅ 今天 ⋅ 0

聊聊spring cloud的HystrixCircuitBreakerConfiguration

序 本文主要研究一下spring cloud的HystrixCircuitBreakerConfiguration HystrixCircuitBreakerConfiguration spring-cloud-netflix-core-2.0.0.RELEASE-sources.jar!/org/springframework/......

go4it ⋅ 今天 ⋅ 0

二分查找

二分查找,也称折半查找、二分搜索,是一种在有序数组中查找某一特定元素的搜索算法。搜素过程从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜素过程结束;如果某一特定元素大于...

人觉非常君 ⋅ 今天 ⋅ 0

VS中使用X64汇编

需要注意的是,在X86项目中,可以使用__asm{}来嵌入汇编代码,但是在X64项目中,再也不能使用__asm{}来编写嵌入式汇编程序了,必须使用专门的.asm汇编文件来编写相应的汇编代码,然后在其它地...

simpower ⋅ 今天 ⋅ 0

ThreadPoolExecutor

ThreadPoolExecutor public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, ......

4rnold ⋅ 昨天 ⋅ 0

Java正无穷大、负无穷大以及NaN

问题来源:用Java代码写了一个计算公式,包含除法和对数和取反,在页面上出现了-infinity,不知道这是什么问题,网上找答案才明白意思是负的无穷大。 思考:为什么会出现这种情况呢?这是哪里...

young_chen ⋅ 昨天 ⋅ 0

前台对中文编码,后台解码

前台:encodeURI(sbzt) 后台:String param = URLDecoder.decode(sbzt,"UTF-8");

west_coast ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部