16.Java 基础
来源:互联网 发布:caffe googlenet 分类 编辑:程序博客网 时间:2024/06/05 04:43
基本概念
Comparable & Comparator 的定义如下:
当一个类实现了 Comparable 接口,表示该类支持排序。
当一个类实现了 Comparator 接口,表示该类是一个比较器。
当一个类不支持排序,即未实现 Comparable 时。要对该类的对象集合或数组进行排序:
- 修改类的结构,该类实现 Comparable 接口。
- 不修改类结构,新建类实现 Comparator 接口,作为该类的比较器。
不难看出,实现 Comparable 接口的方式比实现 Comparator 接口的耦合性要强一些。所以还是推荐尽量使用 Comparator 接口实现排序功能。
原理分析
下面来分析它们的原理:
1.Comparable
当一个类实现了 Comparable 接口,表示该类支持排序。
若存在该类对象的集合或数组,则可以通过 Collections.sort 或 Arrays.sort 进行排序。
接口源码
public interface Comparable<T> { public int compareTo(T o);}
自定义接口实现类
public class Person implements Comparable<Person> { private String name; private int age; public Person(String name, int age) { this.name = name; this.age = age; } @Override public String toString() { return this.name + "-" + this.age; } // 关键 @Override public int compareTo(Person p) { return this.age - p.age; }}
调用
Person[] pers = { new Person("b", 400), new Person("a", 40) };// 排序,默认按从小到大排序Arrays.sort(pers);for (Person per : pers) { System.out.println(per.toString());}// 输出结果:// a-40// b-400
2.Comparator
当一个类本身并没有实现 Comparable 接口,说明该类不支持排序。
这种情况下,仍然要对该类的集合或数组进行排序,则需要创建一个该类的比较器。
新建类实现了 Comparator 接口,表示自己是一个比较器。
接口源码
public interface Comparator<T> { int compare(T o1, T o2); boolean equals(Object obj);}
自定义接口实现类
public class Person { private String name; private int age; // 省略 getter 方法... public Person(String name, int age) { this.name = name; this.age = age; } @Override public String toString() { return this.name + "-" + this.age; }}// 关键 -> 创建 Peerson 类的比较器public class PersonComparator implements Comparator<Person> { @Override public int compare(Person p1, Person p2) { return p1.getAge() - p2.getAge(); }}
调用
Person[] pers = { new Person("b", 400), new Person("a", 40) };PersonComparator pc = new PersonComparator();Arrays.sort(pers,pc);for (Person per : pers) { System.out.println(per.toString());}// 输出结果同上个例子
0 0
- 16.Java 基础
- 【java基础】16.线程
- Java基础01:基础
- Java基础:基础加强
- Java基础-基础
- java基础的基础
- JAVA基础---基础常识
- Java基础:基础加强
- [Java 基础]基础语法
- Java基础
- java基础
- java 基础
- java基础
- Java基础
- Java基础
- Java基础
- JAVA基础
- JAVA基础
- redis WRONGTYPE Operation against a key holding the wrong kind of value
- 记录开机自启日报系统
- Linux权限详解:用户、用户组及文件权限
- Rx 入门(五)-- 转换操作符
- C++ vector<int>向量越界。。。运行段错误退出但gdb未定义到错误位置
- 16.Java 基础
- Linux
- Windows10 Java环境变量配置
- 矩阵乘法 nyoj 623
- POJ 3083(按规定方法遍历)
- 硬件编解码(一)硬件编解码介绍
- 获取高德地图api key
- Unity编程笔录-wikitude简单介绍和使用Android Studio打包apk
- 如何开机自动挂载磁盘,固态硬盘