Arrays 的sort 可以实现简单的排序,如果想对java bean 指定属性字段,或者是多个字段进行比较排序,我自己研究了一下comparable,可以实现指定bo属性的排序。
一)代码
package cn.com.ld.bo;
import java.util.Arrays;
public class StudentInfo implements Comparable {
private String name;
private int age;
private int grate;
private StudentInfo(String name, int age, int grate) {
this.name = name;
this.age = age;
this.grate = grate;
}
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 int getGrate() {
return grate;
}
public void setGrate(int grate) {
this.grate = grate;
}
public int compareTo(Object o) {
int other_grate = ((StudentInfo) o).getGrate();
int other_age = ((StudentInfo) o).getAge();
int result = 0;
if (this.grate > other_grate) {
result = 1;
} else if (this.grate < other_grate) {
result = -1;
} else{
result = (this.age - other_age) > 0 ? -1 : 1 ;
}
return result;
}
public static void main(String[] args) {
StudentInfo[] siArray = new StudentInfo[] {
new StudentInfo("lida_0", 25, 94),
new StudentInfo("lida_1", 23, 95),
new StudentInfo("lida_2", 21, 99),
new StudentInfo("lida_3", 22, 99),
new StudentInfo("lida_4", 22, 100),
new StudentInfo("lida_5", 24, 98),
new StudentInfo("lida_6", 24, 96),
new StudentInfo("lida_7", 20, 97), };
Arrays.sort(siArray);
for (StudentInfo studentInfo : siArray) {
System.out.println(studentInfo.name + " " + studentInfo.age + " "
+ studentInfo.grate);
}
}
}
二)输出结果:
lida_0 25 94
lida_1 23 95
lida_6 24 96
lida_7 20 97
lida_5 24 98
lida_3 22 99
lida_2 21 99
lida_4 22 100
三)小结
public int compareTo(Object o) {
int other_grate = ((StudentInfo) o).getGrate();
int other_age = ((StudentInfo) o).getAge();
int result = 0;
if (this.grate > other_grate) {
result = 1;
} else if (this.grate < other_grate) {
result = -1;
} else{
result = (this.age - other_age) > 0 ? -1 : 1 ;
}
return result;
}
compareTo 里指定了要进行比较的属性。如果不指定比较的属性,默认针对该bean的第一个字段进行排序;升序降序,只需指定 return 的value ;
分享到:
相关推荐
1.什么是Comparable接口 此接口强行对实现它的每个类的对象进行整体排序。此排序被称为该类的自然排序 ,类的 compareTo 方法被称为它的自然比较方法 。实现此接口的对象列表(和数组)可以通过 Collections.sort ...
Java Comparable和Comparator对比详解 Java 中的 Comparable 和 Comparator 是两个常用的接口,用于实现对象的比较和排序。它们都是 Java 中的接口,都是用于比较对象的大小的,但它们有所不同。 Comparable 接口 ...
Java Comparable及Comparator接口区别详解 Java 中的 Comparable 和 Comparator 接口都是用来比较对象大小的,但是它们之间有着非常重要的区别。 首先,让我们来了解一下 Comparable 接口。Comparable 接口位于 ...
Comparable的用法1---马克-to-win java视频的详细描述
Java 实现 Comparable 接口排序,升序、降序、倒叙 Java 中的 Comparable 接口是一个非常重要的接口,它提供了一种排序的机制,允许开发者自定义对象的排序规则。在 Java 中,实现 Comparable 接口的类可以使用 ...
在Java编程语言中,排序是数据处理中一个非常常见的需求,而`Comparator`和`Comparable`接口则是实现排序的关键工具。这两个接口都是用于比较对象,但它们的应用场景和使用方式有所不同。 首先,`Comparable`接口是...
可以看到,上面的代码中,`Comparable()`中的尖括号为空,这是因为Java编译器能够根据上下文自动推断出泛型类型,从而省略了显式的泛型指定。 更进一步,如果匿名内部类只包含一个抽象方法,则可以进一步简化为...
在Java编程语言中,Comparable和Comparator接口是两个重要的概念,它们都用于对象的排序,但有着不同的使用场景和特点。本文将深入探讨这两个接口的区别,以及它们在实际开发中的应用。 首先,我们来了解一下...
在Java编程语言中,Comparable和Comparator接口是两个非常重要的组件,它们主要用来进行对象的比较和排序。了解它们之间的区别对于提升代码的可维护性和灵活性至关重要。 Comparable接口来源于java.lang包,它定义...
Java-中的-Comparator-和-Comparable.md
Comparable 接口是 Java 中的一个接口,它提供了一个通用的比较机制,允许对象之间进行比较。实现 Comparable 接口的类可以使用 Arrays.sort() 方法对其对象数组进行排序。 在上面的示例代码中,我们定义了一个 ...
在 Java 中,Comparator 和 Comparable 是两个非常重要的接口,它们用于对象的排序操作。这两个接口都是在 java.util 包中定义的,主要用于定制排序规则。 **一、Comparator 接口** Comparator 接口允许我们创建...
在Java编程语言中,排序是常见的操作,而`Comparable`和`Comparator`接口则是实现对象排序的两种主要方式。这篇文章将深入探讨这两种实现方式及其在实际编程中的应用。 首先,`Comparable`接口位于`java.lang`包下...
这里我们将深入探讨Java 8 HashMap如何与Comparable接口结合使用,以及这背后的编程技术和设计原理。 首先,我们了解下Comparable接口。Comparable接口是Java中用于定义对象之间自然顺序的接口,它只有一个方法`...
在Java编程语言中,`Comparable`接口和`Comparator`接口是两种重要的排序机制,它们用于对集合中的对象进行比较和排序。理解它们的区别对于任何Java开发者来说都是至关重要的。 首先,`Comparable`接口位于`java....
在Java编程语言中,Comparable和Comparator接口用于对对象进行比较和排序。这两个接口在很多情况下都能派上用场,但它们的应用场景和实现方式有所不同。 首先,Comparable接口是排序接口,意味着一个类如果实现了...
Java 中的 Comparable 和 Comparator 接口详解 Java 中的 Comparable 和 Comparator 接口都是用于比较和排序的,但是它们之间存在着一些关键的区别。Comparable 是一个排序接口,若一个类实现了 Comparable 接口,...
在Java编程语言中,Comparable和Comparator接口用于比较对象的顺序,尤其在进行排序操作时非常关键。两者虽然目的相似,但使用方式和应用场景有所区别。 Comparable接口定义在`java.lang`包中,它只有一个方法`...