java中Collections.sort排序详解[通俗易懂]

java中Collections.sort排序详解[通俗易懂]Comparator是个接口,可重写compare()及equals()这两个方法,用于比价功能;如果是null的话,就是使用元素的默认顺序,如a,b,c,d,e,f,g,就是a,b,c,d,e,f,g这样,当然数字也是这样的。compare(a,b)方法:根据第一个参数小于、等于或大于第二个参数分别返回负整数、零或正整数。equals(obj)方法:仅当指定的对象也是一个Compara

大家好,又见面了,我是你们的朋友全栈君。

java中Collections.sort排序详解[通俗易懂]

 

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;

/**
 * 书实体类
 * 
 * @author yjd
 * 
 */
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));
		}
	}
}

自定义比较器和测试类:

 

 

package com.tjcyjd.comparator;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.GregorianCalendar;
import java.util.Iterator;
import java.util.List;

public class UseComparator {
	public static void main(String args[]) {
		List<Book> list = new ArrayList<Book>(); // 数组序列
		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), "搜狐");
		list.add(b1);
		list.add(b2);
		list.add(b3);
		list.add(b4);
		list.add(b5);
		// Collections.sort(list); //没有默认比较器,不能排序
		System.out.println("数组序列中的元素:");
		myprint(list);
		Collections.sort(list, new PriceComparator()); // 根据价格排序
		System.out.println("按书的价格排序:");
		myprint(list);
		Collections.sort(list, new CalendarComparator()); // 根据时间排序
		System.out.println("按书的出版时间排序:");
		myprint(list);
	}

	// 自定义方法:分行打印输出list中的元素
	public static void myprint(List<Book> list) {
		Iterator it = list.iterator(); // 得到迭代器,用于遍历list中的所有元素
		while (it.hasNext()) {// 如果迭代器中有元素,则返回true
			System.out.println("\t" + it.next());// 显示该元素
		}
	}

	// 自定义比较器:按书的价格排序
	static class PriceComparator implements Comparator {
		public int compare(Object object1, Object object2) {// 实现接口中的方法
			Book p1 = (Book) object1; // 强制转换
			Book p2 = (Book) object2;
			return new Double(p1.price).compareTo(new Double(p2.price));
		}
	}

	// 自定义比较器:按书出版时间来排序
	static class CalendarComparator implements Comparator {
		public int compare(Object object1, Object object2) {// 实现接口中的方法
			Book p1 = (Book) object1; // 强制转换
			Book p2 = (Book) object2;
			return p2.calendar.compareTo(p1.calendar);
		}
	}
}

java中Collections.sort排序详解[通俗易懂]

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/157913.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Linux 修改目录下所有文件权限

    Linux 修改目录下所有文件权限sudochmod777/目录/-R

    2022年7月26日
    7
  • 关于在eclipse中中文汉字乱码的解决方式[通俗易懂]

    关于在eclipse中中文汉字乱码的解决方式[通俗易懂]很多童鞋反应在吧项目导入到eclipse(myeclipse)时中文会有乱码,修改了编码格式后还是乱码,这里给大家介绍一下关于中文乱码时修改编码的注意事项: 当在eclipse中打开一个文件后发现有中文乱码后,千万不能修改这个文件内容,一旦改过这个文件的内容,那怎么修改编码也没用了,只能重新导入。 当打开文件发现乱码后第一步是关闭这个文件,然后在这个文件上右键,选择属性,然后选择编…

    2022年5月26日
    60
  • 固态硬盘故障表现及数据恢复方案表_ssd硬盘数据恢复得了吗

    固态硬盘故障表现及数据恢复方案表_ssd硬盘数据恢复得了吗固态硬盘出现硬件损坏时,通常是NAND控制芯片损坏造成的,主控芯片是固态硬盘的存取控制芯片,是固态硬盘的灵魂所在。相比于闪存颗粒有限的擦写寿命,在闪存颗粒依然坚挺的时候,主控芯片却损坏的概率反而要高得多,据统计,95%以上的固态硬盘故障,都是由于主控芯片发生故障引起的。主控芯片发生故障的表现有以下几种:(1)容量异常,容量识别成8Mb,16M,1G,2G等?(2)容量正常,但通过16进制编辑工具查看硬盘底层信息,只能显示几个在不断重复的扇区(3)可识别硬盘的型号,…

    2022年9月20日
    2
  • mysql opkg源_OpenWrt opkg 在线源默认配置

    mysql opkg源_OpenWrt opkg 在线源默认配置destroot/destram/tmplists_dirext/var/opkg-listsoptionoverlay_root/overlaysrc/gzbarrier_breaker_basehttp://downloads.openwrt.org/barrier_breaker/14.07/x86/generic/packages/basesrc/gzbarrier_…

    2022年6月2日
    46
  • Eclipse断点调试

    Eclipse断点调试作为开发人员,掌握开发环境下的调试技巧十分有必要。去年就想把关于Eclipse断点调试总结下了,由于对时间的掌控程度仍需极大提高,结果拖到今年才写了此篇博文。关于java调试技术还有很多,如JavaDebugInterface等,依据具体项目的需要,还有很多值得去研究和学习的。该博文仅就Eclipse断点调试技巧做下总结,不足够的地方还请大牛们指点。1 Debug视图1.1线程堆栈

    2022年5月21日
    93
  • 个人网站可以申请微信授权登录吗

    个人网站可以申请微信授权登录吗

    2021年10月25日
    56

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号