集合框架(五)使用Comparable接口和Comparator接口来比较元素
来源:互联网 发布:淘宝上卖篮球鞋的店铺 编辑:程序博客网 时间:2024/05/16 02:03
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();
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方法。
- 集合框架(五)使用Comparable接口和Comparator接口来比较元素
- 使用Comparable和Comparator接口比较对象
- Comparable和Comparator接口比较
- 使用TreeSet集合比较Comparable接口和Comparator接口的区别
- 使用TreeSet集合比较Comparable接口和Comparator接口的区别
- 使用TreeSet集合比较Comparable接口和Comparator接口的区别
- 使用TreeSet集合比较Comparable接口和Comparator接口的区别
- 对象的比较--Comparable接口和Comparator接口的使用
- Comparable接口和Comparator接口的使用
- Comparator比较器和Comparable接口
- ):Comparable接口和Comparator接口
- Comparator和Comparable接口
- Comparable 和 Comparator接口
- Comparable和Comparator接口
- Comparator和Comparable接口
- Comparable和Comparator接口
- Comparable和Comparator接口
- 集合排序的两种方法Comparable接口和Comparator接口(比较器)
- linux dns 服务器搭建及配置
- 如何更好的玩转Java
- LaTeX模板
- 跟着实例学习ZooKeeper的用法: Barrier
- CSAPP 深入理解计算机系统 Buflab实验,缓冲区溢出攻击实验(4)
- 集合框架(五)使用Comparable接口和Comparator接口来比较元素
- 个人开发工具汇总
- 黑马程序员——java基础----集合框架知识点总结(一)
- 跟着实例学习ZooKeeper的用法: 临时节点
- TortoiseSVN中Branching和Merging实践
- Perl计数器
- 仿微信通讯录列表
- Android属性动画完全解析(中),ValueAnimator和ObjectAnimator的高级用法
- 第十二周 阅读程序 虚基类 中的继承