JAVA Comparator 接口排序用法
java的比较器有两类,分别是Comparable接口和Comparator接口。
在为对象数组进行排序时,比较器的作用非常明显,首先来讲解Comparable接口。
让需要进行排序的对象实现Comparable接口,重写其中的compareTo(T o)方法,在其中定义排序规则,那么就可以直接调用java.util.Arrays.sort()来排序对象数组,实例如下:
- class Student implements Comparable<Student>{
- private String name;
- private int age;
- private float score;
- public Student(String name, int age, float score) {
- this.name = name;
- this.age = age;
- this.score = score;
- }
- public String toString()
- {
- return name+"\t\t"+age+"\t\t"+score;
- }
- @Override
- public int compareTo(Student o) {
- // TODO Auto-generated method stub
- if(this.score>o.score)//score是private的,为什么能够直接调用,这是因为在Student类内部
- return -1;//由高到底排序
- else if(this.score<o.score)
- return 1;
- else{
- if(this.age>o.age)
- return 1;//由底到高排序
- else if(this.age<o.age)
- return -1;
- else
- return 0;
- }
- }
- }
- public class ComparableDemo01 {
- /**
- * @param args
- */
- public static void main(String[] args) {
- // TODO Auto-generated method stub
- Student stu[]={new Student("zhangsan",20,90.0f),
- new Student("lisi",22,90.0f),
- new Student("wangwu",20,99.0f),
- new Student("sunliu",22,100.0f)};
- java.util.Arrays.sort(stu);
- for(Student s:stu)
- {
- System.out.println(s);
- }
- }
- }
在上面的程序中,实现了Comparable接口,并重写了compareTo方法,将学生先按成绩由大到小排名,成绩相同时候按照年龄由低到高排序。
执行的结果是
sunliu 22 100.0
wangwu 20 99.0
zhangsan 20 90.0
lisi 22 90.0
但是在设计类的时候,可能没有考虑到让类实现Comparable接口,那么就需要用到另外的一个比较器接口Comparator。
从上面的实例我们可以发现,compareTo(T o)只有一个参数,而Comparator接口中必须要实现的compare(T o1,T o2)就有两个参数。
代码实例
- package edu.sjtu.ist.comutil;
- import java.util.Comparator;
- class Student {
- private String name;
- private int age;
- private float score;
- public Student(String name, int age, float score) {
- this.name = name;
- this.age = age;
- this.score = score;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public int getAge() {
- return age;
- }
- public void setAge(int age) {
- this.age = age;
- }
- public float getScore() {
- return score;
- }
- public void setScore(float score) {
- this.score = score;
- }
- public String toString()
- {
- return name+"\t\t"+age+"\t\t"+score;
- }
- }
- class StudentComparator implements Comparator<Student>{
- @Override
- public int compare(Student o1, Student o2) {
- // TODO Auto-generated method stub
- if(o1.getScore()>o2.getScore())
- return -1;
- else if(o1.getScore()<o2.getScore())
- return 1;
- else{
- if(o1.getAge()>o2.getAge())
- return 1;
- else if(o1.getAge()<o2.getAge())
- return -1;
- else
- return 0;
- }
- }
- }
- public class ComparableDemo02 {
- /**
- * @param args
- */
- public static void main(String[] args) {
- // TODO Auto-generated method stub
- Student stu[]={new Student("zhangsan",20,90.0f),
- new Student("lisi",22,90.0f),
- new Student("wangwu",20,99.0f),
- new Student("sunliu",22,100.0f)};
- java.util.Arrays.sort(stu,new StudentComparator());
- for(Student s:stu)
- {
- System.out.println(s);
- }
- }
- }
上面依然是对student对象数组进行排序,用的都是Array.sort方法,不同的是实现comparator接口时,sort方法需要传进来两个参数,即stu对象数组,以及重写的实现了comparator比较方法类。
程序运行的结果和上面是一样的
Array.sort是对数组进行排序,假如我们不想使用数组,想使用Collection接口下的集合,如想使用List,那么需要稍微做些修改:
全部的学生:
0zhangnan3 6778
0zhangnan2 390
2zhangnan1 5796
3zhangnan4 6253
在这里我们没有使用对象数组,而是使用了Collection 接口下的ArrayList 集合,所以排序用的是Collections.sort(st,new ComparatorSort())
java的比较器有两类,分别是Comparable接口和Comparator接口。
在为对象数组进行排序时,比较器的作用非常明显,首先来讲解Comparable接口。
让需要进行排序的对象实现Comparable接口,重写其中的compareTo(T o)方法,在其中定义排序规则,那么就可以直接调用java.util.Arrays.sort()来排序对象数组,实例如下:
- class Student implements Comparable<Student>{
- private String name;
- private int age;
- private float score;
- public Student(String name, int age, float score) {
- this.name = name;
- this.age = age;
- this.score = score;
- }
- public String toString()
- {
- return name+"\t\t"+age+"\t\t"+score;
- }
- @Override
- public int compareTo(Student o) {
- // TODO Auto-generated method stub
- if(this.score>o.score)//score是private的,为什么能够直接调用,这是因为在Student类内部
- return -1;//由高到底排序
- else if(this.score<o.score)
- return 1;
- else{
- if(this.age>o.age)
- return 1;//由底到高排序
- else if(this.age<o.age)
- return -1;
- else
- return 0;
- }
- }
- }
- public class ComparableDemo01 {
- /**
- * @param args
- */
- public static void main(String[] args) {
- // TODO Auto-generated method stub
- Student stu[]={new Student("zhangsan",20,90.0f),
- new Student("lisi",22,90.0f),
- new Student("wangwu",20,99.0f),
- new Student("sunliu",22,100.0f)};
- java.util.Arrays.sort(stu);
- for(Student s:stu)
- {
- System.out.println(s);
- }
- }
- }
在上面的程序中,实现了Comparable接口,并重写了compareTo方法,将学生先按成绩由大到小排名,成绩相同时候按照年龄由低到高排序。
执行的结果是
sunliu 22 100.0
wangwu 20 99.0
zhangsan 20 90.0
lisi 22 90.0
但是在设计类的时候,可能没有考虑到让类实现Comparable接口,那么就需要用到另外的一个比较器接口Comparator。
从上面的实例我们可以发现,compareTo(T o)只有一个参数,而Comparator接口中必须要实现的compare(T o1,T o2)就有两个参数。
代码实例
- package edu.sjtu.ist.comutil;
- import java.util.Comparator;
- class Student {
- private String name;
- private int age;
- private float score;
- public Student(String name, int age, float score) {
- this.name = name;
- this.age = age;
- this.score = score;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public int getAge() {
- return age;
- }
- public void setAge(int age) {
- this.age = age;
- }
- public float getScore() {
- return score;
- }
- public void setScore(float score) {
- this.score = score;
- }
- public String toString()
- {
- return name+"\t\t"+age+"\t\t"+score;
- }
- }
- class StudentComparator implements Comparator<Student>{
- @Override
- public int compare(Student o1, Student o2) {
- // TODO Auto-generated method stub
- if(o1.getScore()>o2.getScore())
- return -1;
- else if(o1.getScore()<o2.getScore())
- return 1;
- else{
- if(o1.getAge()>o2.getAge())
- return 1;
- else if(o1.getAge()<o2.getAge())
- return -1;
- else
- return 0;
- }
- }
- }
- public class ComparableDemo02 {
- /**
- * @param args
- */
- public static void main(String[] args) {
- // TODO Auto-generated method stub
- Student stu[]={new Student("zhangsan",20,90.0f),
- new Student("lisi",22,90.0f),
- new Student("wangwu",20,99.0f),
- new Student("sunliu",22,100.0f)};
- java.util.Arrays.sort(stu,new StudentComparator());
- for(Student s:stu)
- {
- System.out.println(s);
- }
- }
- }
上面依然是对student对象数组进行排序,用的都是Array.sort方法,不同的是实现comparator接口时,sort方法需要传进来两个参数,即stu对象数组,以及重写的实现了comparator比较方法类。
程序运行的结果和上面是一样的
Array.sort是对数组进行排序,假如我们不想使用数组,想使用Collection接口下的集合,如想使用List,那么需要稍微做些修改:
全部的学生:
0 zhangnan3 67 78
0 zhangnan2 39 0
2 zhangnan1 57 96
3 zhangnan4 62 53
在这里我们没有使用对象数组,而是使用了Collection 接口下的ArrayList 集合,所以排序用的是Collections.sort(st,new ComparatorSort())
JAVA Comparator 接口排序用法的更多相关文章
- Java Comparator接口学习笔记
Comparator是一个泛型函数式接口,T表示待比较对象的类型: @FunctionalInterface public interface Comparator<T> { } 本文将主 ...
- Java Comparator字符排序(数字、字母、中文混合排序)
Java.lang.Character类 复习一下 这是修正前的排序效果: 这是修正后的排序效果: 完整示例: 以下是排序的部份代码(非全部代码:拼音首字母算法不在其中) import java.ut ...
- java Comparator比较器排序法
注意:排序的字段不为空,否则抛出空指针异常! 第一步:先编写一个比较器类 如下: 第二步:此集合的对象 EO 必须重写 此equals 方法 如图: 第三步:调用使用此比较器 如图:
- JAVA排序(二) Comparator接口
接着说关于Comparator接口, java.util Interface Comparator<T>(该泛型指定的是被比较的类),使用该接口不需要在待比较类进行比较操作,即在不修改源码 ...
- Java TreeSet集合排序 && 定义一个类实现Comparator接口,覆盖compare方法 && 按照字符串长度排序
package TreeSetTest; import java.util.Iterator; import java.util.TreeSet; import javax.management.Ru ...
- Java之——利用Comparator接口对多个排序条件进行处理
转载自:http://blog.csdn.net/l1028386804/article/details/56513205 膜拜大神··· 一.需求 假设现在有个如此的需求:需要对一个这样的雇员列表进 ...
- JAVA 使用Comparator接口实现自定义排序
1.原则 Comparator接口可以实现自定义排序,实现Comparator接口时,要重写compare方法: int compare(Object o1, Object o2) 返回一个基本类型的 ...
- 我的Java开发学习之旅------>Java利用Comparator接口对多个排序条件进行处理
一需求 二实现Comparator接口 三验证排序结果 验证第一条件首先按级别排序级别最高的排在前面 验证第二条如果级别相等那么按工资排序工资高的排在前面 验证第三条如果工资相当则按入职年数排序入职时 ...
- java自定义类型 比较排序 Comparator接口
String service_time = "6:00:00,7:00:00,8:00:00,9:00:00,10:00:00,11:00:00,12:00:00,13:00:00,14:0 ...
随机推荐
- 【Unity笔记】经典的鼠标点击射线检测碰撞
void Update (){ )){ //从摄像机发出到点击坐标的射线 Ray ray = Camera.main.ScreenPointToRay(Input.mousePosition); Ra ...
- [systemd]How To Use Systemctl to Manage Systemd Services and Units
转自: https://www.digitalocean.com/community/tutorials/how-to-use-systemctl-to-manage-systemd-services ...
- php7+apache2.4 安装(window)
一.下载 需要下载 php7.apache2.4.vc2015(VC库) PHP7下载地址:http://windows.php.net/download/ Apache 下载地址:https://h ...
- 【Qt Tips】QLineEdit内容过滤之setValidator和setInputMask浅析
1.QValidator分析 2.InputMask格式 3.测试代码和用例 项目路径: GitHub: https://github.com/Qunero/NeoQtTestDemo/tree/ma ...
- [爬虫]Python爬虫进阶
请跳转到以下页面查看: 爬虫进阶
- SQL与NoSQL的CRUD对照
SQL与NoSQL的CRUD对照 flyfish 2015-7-21 Create, Read, Update and Delete (CRUD) SQL方式 查 SELECT 列名称 FROM 表名 ...
- php-config 介绍
php-config php-config 是一个简单的命令行脚本用于获取所安装的 PHP 配置的信息. 在编译扩展时,如果安装有多个 PHP 版本,可以在配置时用 --with-php-config ...
- 百万级PHP网站架构工具箱
在了解过世界最大的PHP站点,Facebook的后台技术后,今天我们来了解一个百万级PHP站点的网站架构:Poppen.de.Poppen.de是德国的一个社交网站,相对Facebook.Flickr ...
- jquery json解析详解
我们先以解析上例中的comments对象的JSON数据为例,然后再小结jQuery中解析JSON数据的方法. JSON数据如下,是一个嵌套JSON: 1 {"comments":[ ...
- Windoows窗口程序二
WNDCLASS属性style取值: CS_GLOBALCLASS--应用程序全局窗口类 CS_BYTEALIGNCLIENT--窗口客户区的水平位置8倍数对齐 CS_BYTEALIGNWINDOW- ...