第一个例子

  1. /*为了比较,让自己的类实现Comparable接口,按照自己想要的排序方式重写compareTo
  2. *Map只是提供了对键的排序,但是当我们需要对值排序时就的提供我们自己的比较器 这里 只是模拟了Map但是实际上并没有使用Map
  3. */
  4. import java.util.Iterator;
  5. import java.util.Set;
  6. import java.util.TreeSet;
  7. public class SortByValue {
  8. public static void main(String[] args) {
  9. Set<Pair> set = new TreeSet<Pair>();
  10. set.add(new Pair("me", "1000"));
  11. set.add(new Pair("and", "4000"));
  12. set.add(new Pair("you", "3000"));
  13. set.add(new Pair("food", "10000"));
  14. set.add(new Pair("hungry", "5000"));
  15. set.add(new Pair("later", "6000"));
  16. set.add(new Pair("myself", "1000"));
  17. for (Iterator<Pair> i = set.iterator(); i.hasNext();)
  18. // 我喜欢这个for语句
  19. System.out.println(i.next());
  20. }
  21. }
  22. class Pair implements Comparable<Object> {
  23. private final String name;
  24. private final int number;
  25. public Pair(String name, int number) {
  26. this.name = name;
  27. this.number = number;
  28. }
  29. public Pair(String name, String number) throws NumberFormatException {
  30. this.name = name;
  31. this.number = Integer.parseInt(number);
  32. }
  33. public int compareTo(Object o) {
  34. if (o instanceof Pair) {
  35. // int cmp = Double.compare(number, ((Pair) o).number);
  36. int cmp = number - ((Pair) o).number;
  37. if (cmp != 0) {// number是第一要比较的,相当于先比较value。如果相同再比较键
  38. return cmp;
  39. }
  40. return name.compareTo(((Pair) o).name);
  41. }
  42. throw new ClassCastException("Cannot compare Pair with "
  43. + o.getClass().getName());
  44. }
  45. public String toString() {
  46. return name + ' ' + number;
  47. }
  48. }
  49. 输出结果:
  50. me 1000
  51. myself 1000
  52. you 3000
  53. and 4000
  54. hungry 5000
  55. later 6000
  56. food 10000

第二个例子:

  1. import java.util.*;
  2. public class NameSort {
  3. public static void main(String[] args) {
  4. Name[] nameArray = { new Name("John", "Lennon"),
  5. new Name("Karl", "Marx"), new Name("Groucho", "Marx"),
  6. new Name("Oscar", "Grouch") };
  7. Arrays.sort(nameArray);  //根据元素的自然顺序对指定对象数组按升序进行排序。数组中的所有元素都必须实现 Comparable 接口。此外,数组中的所有元                                      //素都必须是可相互比较的(也就是说,对于数组中的任何 e1e2 元素而言,e1.compareTo(e2) 不得抛出 ClassCastException)。
  8. for (int i = 0; i < nameArray.length; i++) {
  9. System.out.println(nameArray[i].toString());
  10. }
  11. }
  12. }
  13. class Name implements Comparable<Name> {
  14. public String firstName, lastName;
  15. public Name(String firstName, String lastName) {
  16. this.firstName = firstName;
  17. this.lastName = lastName;
  18. }
  19. public int compareTo(Name o) { // 实现接口
  20. int lastCmp = lastName.compareTo(o.lastName);
  21. // 首先比较姓(lastName)如果姓相同(lastCmp==0)再比较名(firstName),否则返回名的比较
  22. return (lastCmp == 0 ? firstName.compareTo(o.firstName) : lastCmp);
  23. }
  24. public String toString() { // 便于输出测试
  25. return firstName + " " + lastName;
  26. }
  27. }
  28. 输出结果:
  29. Oscar Grouch
  30. John Lennon
  31. Groucho Marx
  32. Karl Marx
    1. //看看这个三目运算符的漂亮应用哦!
    2. public int compareTo(Pair o) {
    3. int cmp = number - o.number;
    4. return (cmp == 0 ? name.compareTo(o.name) : cmp);
    5. }
    6. ----------------------
    7. public int compareTo(Name o) { // 实现接口
    8. int lastCmp = lastName.compareTo(o.lastName);
    9. // 首先比较姓(lastName)如果姓相同(lastCmp==0)再比较名(firstName),否则返回名的比较
    10. return (lastCmp == 0 ? firstName.compareTo(o.firstName) : lastCmp);  
      1. }

        本文转载至:http://ocaicai.iteye.com/blog/794438

对象排序,compareTo的更多相关文章

  1. List对象排序的通用方法

    转自 @author chenchuang import java.lang.reflect.InvocationTargetException;import java.lang.reflect.Me ...

  2. [个人原创]关于java中对象排序的一些探讨(三)

    这篇文章由十八子将原创,转载请注明,并标明博客地址:http://www.cnblogs.com/shibazijiang/ 对对象排序也可以使用Guava中的Ordering类. 构造Orderin ...

  3. Java集合中对象排序

    集合中的对象排序需求还是比較常见的.当然我们能够重写equals方法,循环比較:同一时候Java为我们提供了更易使用的APIs.当须要排序的集合或数组不是单纯的数字型时,通常能够使用Comparato ...

  4. java对对象排序

    一.前言 有时我们需要对类按照类中的某一个属性(或者多个属性)来对类的对象进行排序,有两种方法可以实现,一种方法是类实现Comparable<T>接口,然后调用Collections.so ...

  5. java 通用对象排序

    一个排序类,一个排序util? no.no.no…… 使用反射机制,写了一个通用的对象排序util,欢迎指正. 实体类: package entity; public class BaseTypeEn ...

  6. wpf 导出Excel Wpf Button 样式 wpf简单进度条 List泛型集合对象排序 C#集合

    wpf 导出Excel   1 private void Button_Click_1(object sender, RoutedEventArgs e) 2 { 3 4 ExportDataGrid ...

  7. javascript数组对象排序

    javascript数组对象排序 JavaScript数组内置排序函数 javascript内置的sort函数是多种排序算法的集合 JavaScript实现多维数组.对象数组排序,其实用的就是原生的s ...

  8. Java - 简单的对象排序 - Comparator

    注:对象排序,就是对对象中的某一字段进行比较,以正序或倒序进行排序. 例: 需要排序的对象: public class Person { public int age; public String n ...

  9. list排序成员函数对string对象与char*对象排序的差别

    对list容器中的对象排序,不能使用sort()算法,只能采用其自身的排序函数sort().因为,算法sort()只支持随机存取的容器的排序,如vector等. 对基本数据对象list排序:成员函数s ...

  10. js中的数组对象排序(方法sort()详细介绍)

    定义和用法 sort() 方法用于对数组的元素进行排序. 语法    arrayObject.sort(sortby) 参数sortby:可选.规定排序顺序.必须是函数. 返回值 对数组的引用.请注意 ...

随机推荐

  1. Web 播放声音 — AMR(Audio) 篇

    本文主要介绍 AMR(Aduio) 播放 AMR 格式 Base64码 音频. 1.必备资料 github AMR 开源库 :https://github.com/jpemartins/amr.js用 ...

  2. Web 2D/3d

    首选应该是H5,通过现成的js库来实现,兼容性应该不错 其次可以考虑使用Unity3d,开发起来应该比较快 搜集点资料先放起来~ Unity3d: http://unity3d.com/cn/get- ...

  3. jQuery属性操作

    jQuery 的属性操作的核心部分其实就是对底层 getAttribute().setAttributes()等方法的一系列兼容性处理 ...if ( notxml ) { name = name.t ...

  4. 捷波朗 jabra BT3030 蓝牙耳机

    蓝牙版本V2.0 通话时间 8小时 按键说明:轻敲 快按轻敲两下 在1.5秒内快速按两下按 大约 1秒钟按住 大约 4秒钟 充电提示绿灯闪亮 正在充电持续绿灯 已完全充满电 检查电量按 音量上调(+) ...

  5. 判断是否IPv6网络

    bool isIPV6Net(const std::string ip_v4, std::string& out_ip) { bool is_v6 = false; struct addrin ...

  6. 使用java mail 发送邮件

    1.关联jar包:   activation.jar   mail.jar 2.调用 @Test public void test1() { List<String> imageUrlLi ...

  7. MyBatis foreach标签遍历数组

    有时候开发中需要根据多个ID去查询,可以将ID封装为List或者数组然后使用MyBatis中的foreach标签构建in条件. 这里我将ID封装为String[]作为参数. <select id ...

  8. iOS中什么是superView?(新手概念简述版)

    文/司马陶冶(简书作者)/文章有删改原文链接:http://www.jianshu.com/p/8537dac37852 著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 在iPhone ...

  9. JSON对象转换问题

    今天调用别人接口遇到一个问题,原本约定的data格式为:JSON字符串,但本次返回了一个空字符串"", 大概是这样的 字符串类型的httpResult.data值为字result: ...

  10. ThreadLocal是什么?保证线程安全

    早在JDK 1.2的版本中就提供Java.lang.ThreadLocal,ThreadLocal为解决多线程程序的并发问题提供了一种新的思路.使用这个工具类可以很简洁地编写出优美的多线程程序. 当使 ...