/**
* 一个自定义对象,比较用
*/
public class User {
private String id;
private int age;
public User(String id, int age) {
this.id = id;
this.age = age;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
}
import java.util.Arrays;
/**
* 强行对实现它的每个类的对象进行整体排序,实现此接口的对象列表(和数组)可以通过<br/>
* Collections.sort或Arrays.sort进行自动排序。
*/
public class SimpleComparable implements Comparable<Object> {
/**
* @return 该对象小于、等于或大于指定对象o,分别返回负整数、零或正整数。
*/
@Override
public int compareTo(Object o) {
return this.age - ((SimpleComparable) o).getAge();
}
private String id;
private int age;
public SimpleComparable(String id, int age) {
this.id = id;
this.age = age;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
/**
* 测试方法
*/
public static void main(String[] args) {
SimpleComparable[] users = new SimpleComparable[] {
new SimpleComparable("a", 30), new SimpleComparable("b", 20) };
Arrays.sort(users);
for (int i = 0; i < users.length; i++) {
SimpleComparable user = users[i];
System.out.println(user.getId() + " " + user.getAge());
}
}
}
import java.util.Arrays;
import java.util.Comparator;
/**
* 本例子是为了和SimpleComparable比较用<br/>
* (1)、Comparator 是不对排序对象本身做修改<br/>
* (2)、Comparable 则需要排序对象是实现<br/>
* 一个类实现了Comparable接口则表明这个类的对象之间是可以相互比较的,这个类对象<br/>
* 组成的集合就可以直接使用sort方法排序。<br/.
* Comparator可以看成一种算法的实现,将算法和数据分离,Comparator在下面两种环境下使用:
* (1)、类的设计师没有考虑到比较问题而没有实现Comparable,可以通过Comparator来实现<br/>
* 排序而不必改变对象本身 <br/>
* (2)、可以使用多种排序标准,比如升序、降序等
*/
public class SimpleComparator implements Comparator<Object> {
/**
* @return o1小于、等于或大于o2,分别返回负整数、零或正整数。
*/
@Override
public int compare(Object o1, Object o2) {
return ((User) o1).getAge() - ((User) o2).getAge();
}
/**
* 强行对某个对象collection进行整体排序的比较函数,可以将Comparator传递给<br/>
* Collections.sort或Arrays.sort。
*/
public static void main(String[] args) {
User[] users = new User[] { new User("a", 30), new User("b", 20) };
Arrays.sort(users, new SimpleComparator());
for (int i = 0; i < users.length; i++) {
User user = users[i];
System.out.println(user.getId() + " " + user.getAge());
}
}
}
分享到:
相关推荐
java排序Comparator和Comparable
教你学会Comparator和Comparable
java的Comparator和Comparable
comparator接口与Comparable接口的区别
Java-中的-Comparator-和-Comparable.md
Comparable&Comparator区别,看完就明白了
本文,先介绍Comparable 和Comparator两个接口,以及它们的差异;接着,通过示例,对它们的使用方法进行说明
NULL 博文链接:https://hellogava.iteye.com/blog/1570101
通过简单的例子初步了解Comparable和Comparator的使用,注释很详细
主要介绍了java 中Comparable与Comparator详解与比较的相关资料,需要的朋友可以参考下
Java中Comparable和Comparator的区别共3页.pdf.zip
详细的介绍了Java中Comparable与Comparator的区别
用Comparator 的好处是不需要修改源代码, 而是另外实现一个比较器, 当某个自定义的对象需要作比较的时候,把比较器和对象一起传递过去就可以比大小了, 并
Comparable和Comparator接口都可用作普通意义上对象间的比大小,但两个接口在实例化方面的用法不尽相同,接下来我们就来详细对比Java中的Comparable排序接口和Comparator比较器接口
Comparable与Comparator的区别Java开发Java经验技巧共3页.pdf.zip
主要针对Java中Comparable和Comparator对象进行比较,感兴趣的小伙伴们可以参考一下
主要介绍了Java Comparable和Comparator对比详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
以下是一些 Java 集合方面的面试题: Java 中集合框架的主要接口是什么? ArrayList 和 LinkedList 有什么区别? HashSet 和 TreeSet 有什么区别? HashMap 和 TreeMap 有什么区别? 什么是迭代器?如何使用它来遍历...