集合框架(五)使用Comparable接口和Comparator接口来比较元素
2015-06-01 20:21
435 查看
1、有时希望将元素插入到一个树集合中个,这些元素可能不是java.lang.Comparable的实例,这时可以定义一个比较器来比较这些元素。即需要创建一个实现java.util.Comparator接口的类。Comparator接口有两个方法:compare和equals。
public int compare(Object element1, Object element2)
如果element1小于element2,就返回一个负值;如果element1大于element2,就返回一个正值;若两者相等,则返回0。
public boolean equals(Object element)
如果指定的对象也是一个比较器,并且与这个比较器具有相同的排序,则返回true。
2、虽然Object类中也定义了equals方法,所以即使在比较器类中没有实现equals方法也不会出现编译错误,不过,有时实现该方法可以提高运行效率,可以让程序快速判断两个不同的比较器是否具有相同的排序。
3、通常对于比较器来说,实现Serializable是一个好主意,因为,它们可以被用作像TreeSet这样的可序列化数据结构的排序方法。为了使数据结构能够成功序列化,比较器必须实现Serializable接口。
GeometricObjcetComparator.java
import java.util.Comparator;
public class GeometricObjectComparator implement Comparator, java.io.Serializable{
public int compare(GeometricObject o1, GeometricObject o2){
double area1 = o1.getArea();
double area2 = o2.getArea();
}
演示如何使用Comparator接口对树形集中的元素进行排序。
TestTreeSetWithComparator.java
import java.util.*;
public class TestTreeSetWithComparator{
public static void main(String[] args){
//Create a tree set for geometric objects using a comparator
Set set = new TreeSet(new GeometricObjectComparator());
set.add(new Rectangle(4, 5));
set.add(new Circle(40));
set.add(new Circle(40));
set.add(new Rectangle(4, 1));
}
A sorted set of geometric objects
area = 4.0
area = 20.0
area = 5022.5482453669
Circle类和Rectangle类都是几何类GeometricObject的子类
注意:Comparable用于比较实现Comparable的类的对象;Comparator用于比较没有实现Comparable的类的对象。
为什么能排序,跟你怎么实现Comparator接口无关。之所以能排序,是因为TreeSet在存入元素的时候,会按照二叉树的排序规则,将你要存入的元素和已存在的元素进行比较,而比较结果所依据的就是你传入的实现了Comparator接口的匿名对象的compare方法。
public int compare(Object element1, Object element2)
如果element1小于element2,就返回一个负值;如果element1大于element2,就返回一个正值;若两者相等,则返回0。
public boolean equals(Object element)
如果指定的对象也是一个比较器,并且与这个比较器具有相同的排序,则返回true。
2、虽然Object类中也定义了equals方法,所以即使在比较器类中没有实现equals方法也不会出现编译错误,不过,有时实现该方法可以提高运行效率,可以让程序快速判断两个不同的比较器是否具有相同的排序。
3、通常对于比较器来说,实现Serializable是一个好主意,因为,它们可以被用作像TreeSet这样的可序列化数据结构的排序方法。为了使数据结构能够成功序列化,比较器必须实现Serializable接口。
GeometricObjcetComparator.java
import java.util.Comparator;
public class GeometricObjectComparator implement Comparator, java.io.Serializable{
public int compare(GeometricObject o1, GeometricObject o2){
double area1 = o1.getArea();
double area2 = o2.getArea();
if(area1 < area2) return -1; else if(area1 == area2) return 0; else return 1; }
}
演示如何使用Comparator接口对树形集中的元素进行排序。
TestTreeSetWithComparator.java
import java.util.*;
public class TestTreeSetWithComparator{
public static void main(String[] args){
//Create a tree set for geometric objects using a comparator
Set set = new TreeSet(new GeometricObjectComparator());
set.add(new Rectangle(4, 5));
set.add(new Circle(40));
set.add(new Circle(40));
set.add(new Rectangle(4, 1));
//Display geometric objects in the tree set System.out.println("A sorted set of geometric objects"); for(GeometricObject element: set) System.out.println("area = " + element.getArea()); }
}
A sorted set of geometric objects
area = 4.0
area = 20.0
area = 5022.5482453669
Circle类和Rectangle类都是几何类GeometricObject的子类
注意:Comparable用于比较实现Comparable的类的对象;Comparator用于比较没有实现Comparable的类的对象。
为什么能排序,跟你怎么实现Comparator接口无关。之所以能排序,是因为TreeSet在存入元素的时候,会按照二叉树的排序规则,将你要存入的元素和已存在的元素进行比较,而比较结果所依据的就是你传入的实现了Comparator接口的匿名对象的compare方法。
相关文章推荐
- AVG 7.5.1.43 版本 序列号 集合
- SQL Server游标的使用/关闭/释放/优化小结
- C#检查指定对象是否存在于ArrayList集合中的方法
- C#中的集合用法分析
- JavaScript Archive Network 集合
- Backbone.js中的集合详解
- jQuery学习7 操作JavaScript对象和集合的函数
- 网页代码常用小技巧总结第1/3页
- 详解JAVA高质量代码之数组与集合
- 基于Java回顾之集合的总结概述
- 探讨:如何使用委托,匿名方法对集合进行万能排序
- JavaScript中的集合及效率
- C#各种集合操作的性能总结
- java比较器comparator使用示例分享
- Java 中Comparable和Comparator区别比较
- html的DOM中document对象forms集合用法实例
- html的DOM中document对象anchors集合用法实例
- html的DOM中document对象images集合用法实例
- java实现列表、集合与数组之间转化的方法
- Java中集合和数组的排序方式小结