返回顶部
首页 > 资讯 > 精选 >详解Java中Collections.sort排序
  • 422
分享到

详解Java中Collections.sort排序

javacollections.sort排序 2023-05-31 16:05:36 422人浏览 安东尼
摘要

Comparator是个接口,可重写compare()及equals()这两个方法,用于比价功能;如果是null的话,就是使用元素的默认顺序,如a,b,c,d,e,f,g,就是a,b,c,d,e,f,g这样,当然数字也是这样的。compar

Comparator是个接口,可重写compare()及equals()这两个方法,用于比价功能;如果是null的话,就是使用元素的默认顺序,如a,b,c,d,e,f,g,就是a,b,c,d,e,f,g这样,当然数字也是这样的。

compare(a,b)方法:根据第一个参数小于、等于或大于第二个参数分别返回负整数、零或正整数。

equals(obj)方法:仅当指定的对象也是一个 Comparator,并且强行实施与此 Comparator 相同的排序时才返回 true。

Collections.sort(list, new PriceComparator());的第二个参数返回一个int型的值,就相当于一个标志,告诉sort方法按什么顺序来对list进行排序。

具体实现代码方法如下:

Book实体类:

package com.tjcyjd.comparator; import java.text.DecimalFORMat; import java.text.SimpleDateFormat; import java.util.GreGorianCalendar; import java.util.Iterator; import java.util.TreeMap;  public class Book implements Comparable { // 定义名为Book的类,默认继承自Object类   public int id;// 编号   public String name;// 名称   public double price; // 价格   private String author;// 作者   public GregorianCalendar calendar;// 出版日期   public Book() {     this(0, "X", 0.0, new GregorianCalendar(), "");   }   public Book(int id, String name, double price, GregorianCalendar calender,       String author) {     this.id = id;     this.name = name;     this.price = price;     this.calendar = calender;     this.author = author;   }   // 重写继承自父类Object的方法,满足Book类信息描述的要求   public String toString() {     String showStr = id + "\t" + name; // 定义显示类信息的字符串     DecimalFormat formatPrice = new DecimalFormat("0.00");// 格式化价格到小数点后两位     showStr += "\t" + formatPrice.format(price);// 格式化价格     showStr += "\t" + author;     SimpleDateFormat formatDate = new SimpleDateFormat("yyyy年MM月dd日");     showStr += "\t" + formatDate.format(calendar.getTime()); // 格式化时间     return showStr; // 返回类信息字符串   }   public int compareTo(Object obj) {// Comparable接口中的方法     Book b = (Book) obj;     return this.id - b.id; // 按书的id比较大小,用于默认排序   }   public static void main(String[] args) {     Book b1 = new Book(10000, "红楼梦", 150.86, new GregorianCalendar(2009,         01, 25), "曹雪芹、高鄂");     Book b2 = new Book(10001, "三国演义", 99.68, new GregorianCalendar(2008, 7,         8), "罗贯中 ");     Book b3 = new Book(10002, "水浒传", 100.8, new GregorianCalendar(2009, 6,         28), "施耐庵 ");     Book b4 = new Book(10003, "西游记", 120.8, new GregorianCalendar(2011, 6,         8), "吴承恩");     Book b5 = new Book(10004, "天龙八部", 10.4, new GregorianCalendar(2011, 9,         23), "搜狐");     TreeMap tm = new TreeMap();     tm.put(b1, new Integer(255));     tm.put(b2, new Integer(122));     tm.put(b3, new Integer(688));     tm.put(b4, new Integer(453));     tm.put(b5, new Integer(40));     Iterator it = tm.keySet().iterator();     Object key = null, value = null;     Book bb = null;     while (it.hasNext()) {       key = it.next();       bb = (Book) key;       value = tm.get(key);       System.out.println(bb.toString() + "\t库存:" + tm.get(key));     }   } } 

--结束END--

本文标题: 详解Java中Collections.sort排序

本文链接: https://lsjlt.com/news/226818.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 详解Java中Collections.sort排序
    Comparator是个接口,可重写compare()及equals()这两个方法,用于比价功能;如果是null的话,就是使用元素的默认顺序,如a,b,c,d,e,f,g,就是a,b,c,d,e,f,g这样,当然数字也是这样的。compar...
    99+
    2023-05-31
    java collections.sort 排序
  • Java使用Collections.sort()排序的方法
    Java中Collections.sort()的使用 在日常开发中,很多时候都需要对一些数据进行排序的操作。然而那些数据一般都是放在一个集合中如:Map ,Set ,List 等集...
    99+
    2024-04-02
  • Java中Collections.sort对List排序的方法有哪些
    本篇内容介绍了“Java中Collections.sort对List排序的方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、Col...
    99+
    2023-06-21
  • Java使用Collections.sort对中文进行排序方式
    目录使用Collections.sort对中文进行排序Collections.sort 排序 注解使用Collections.sort对中文进行排序 使用collections.so...
    99+
    2024-04-02
  • 浅谈Java中Collections.sort对List排序的两种方法
    目录一、Collections.sort的简单使用二、问题提出三、Comparable实现排序四、Comparator实现排序五、Comparable 与Comparator区别一、...
    99+
    2024-04-02
  • Java如何使用Collections.sort对中文进行排序方式
    本篇文章为大家展示了Java如何使用Collections.sort对中文进行排序方式,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。使用Collections.sort对中文进行排序使用collec...
    99+
    2023-06-25
  • List排序怎么用Collections.sort和Comparator
    小编给大家分享一下List排序怎么用Collections.sort和Comparator,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! public boolean checkCourseTimes(List sched...
    99+
    2023-06-03
  • Java桶排序之基数排序详解
    基数排序也是桶排序的一种,也是跟样本数据强相关的,且基数排序要求样本数据是非负的十进制数,如果有小数或者负数,那么代码将要大量重写!这就是不基于比较的排序的弊端。一般来说,我们认为基...
    99+
    2024-04-02
  • java排序算法之选择排序详解
    本文实例为大家分享了java排序算法之选择排序的具体代码,供大家参考,具体内容如下 选择排序 选择排序的思路是这样的:首先,找到数组中最小的元素,拎出来,将它和数组的第一个元素交换位...
    99+
    2024-04-02
  • java冒泡排序和选择排序详解
    目录1、冒泡排序2、选择排序法总结1、冒泡排序 冒泡排序(Bubble Sorting)的基本思想是:通过对待 排序序列从前向后(从下标较小的元素开始),依次比较相邻元素的值,若发...
    99+
    2024-04-02
  • JAVA十大排序算法之堆排序详解
    目录堆排序知识补充二叉树满二叉树完全二叉树二叉堆代码实现时间复杂度算法稳定性思考总结堆排序 这里的堆并不是JVM中堆栈的堆,而是一种特殊的二叉树,通常也叫作二叉堆。它具有以下特点: ...
    99+
    2024-04-02
  • JAVA十大排序算法之桶排序详解
    目录桶排序代码实现时间复杂度算法稳定性总结桶排序 桶排序是计数排序的升级,计数排序可以看成每个桶只存储相同元素,而桶排序每个桶存储一定范围的元素,通过函数的某种映射关系,将待排序数组...
    99+
    2024-04-02
  • 详解Java之冒泡排序与选择排序
    目录一.冒泡排序1.概念2.图解3.代码的思路4.代码例子二.选择排序1.概念2.图解3.代码的思路总结一.冒泡排序 1.概念 冒泡排序这种排序方法其实关键词就在于冒泡两个字,顾名思...
    99+
    2024-04-02
  • Java中sort排序函数实例详解
    目录前言升序排序降序排序排序原理总结前言 手写一个排序算法的效率是很慢的,当然这也不利于我们在比赛或者工程中的实战,如今几乎每个语言的标准库中都有排序算法,今天让我来给大家讲解一下J...
    99+
    2024-04-02
  • JAVA十大排序算法之冒泡排序详解
    目录冒泡排序代码实现代码实现时间复杂度算法稳定性总结冒泡排序 1.从数组头开始,比较相邻的元素。如果第一个比第二个大(小),就交换它们两个 2.对每一对相邻元素作同样的工作,从开始第...
    99+
    2024-04-02
  • JAVA十大排序算法之选择排序详解
    目录选择排序代码实现动图演示代码实现时间复杂度算法稳定性总结选择排序 1.找到数组中最大(或最小)的元素 2.将它和数组的第一个元素交换位置(如果第一个元素就是最大(小)元素那么它就...
    99+
    2024-04-02
  • JAVA十大排序算法之插入排序详解
    目录插入排序代码实现动图演示代码实现时间复杂度算法稳定性总结插入排序 当我们在玩扑克牌的时候,总是在牌堆里面抽取最顶部的一张然后按顺序在手中排列。 插入排序是指在待排序的元素中,假设...
    99+
    2024-04-02
  • JAVA十大排序算法之希尔排序详解
    目录希尔排序代码实现时间复杂度算法稳定性总结希尔排序 一种基于插入排序的快速的排序算法。简单插入排序对于大规模乱序数组很慢,因为元素只能一点一点地从数组的一端移动到另一端。例如,如果...
    99+
    2024-04-02
  • JAVA十大排序算法之归并排序详解
    目录归并排序怎么分怎么治代码实现时间复杂度算法稳定性总结归并排序 归并,指合并,合在一起。归并排序(Merge Sort)是建立在归并操作上的一种排序算法。其主要思想是分而治之。什么...
    99+
    2024-04-02
  • JAVA十大排序算法之快速排序详解
    目录快速排序问题思路荷兰国旗问题代码实现时间复杂度算法稳定性总结快速排序 快速排序是对冒泡排序的一种改进,也是采用分治法的一个典型的应用。JDK中Arrays的sort()方法,具体...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作