1. 要求
对List列表中的数据进行排序(正序、倒序),列表中的数据包括:整型(Integer)、字符串(String)、日期(Date)等。对于字符串,要求允许对它按照整型进行排序。
2. 实现思路
1. 对于整型、字符串、日期等数据,可以直接调用Collections.sort方法实现排序(正序、倒序)。
2. 对于字符串按照整型排序,可以写一个类实现Comparable接口,在compare方法中将字符转换为整型进行比较;然后再调用Collections.sort的方法,传进一个Comparator来实现。
3. 实现代码
package com.clzhang.sample.collections; import java.util.*; public class CollectionSortTest { // 字符串按照整型排序比较器 static class Str2IntComparator implements Comparator<String> { private boolean reverseOrder; // 是否倒序 public Str2IntComparator(boolean reverseOrder) { this.reverseOrder = reverseOrder; } public int compare(String arg0, String arg1) { if(reverseOrder) return Integer.parseInt(arg1) - Integer.parseInt(arg0); else return Integer.parseInt(arg0) - Integer.parseInt(arg1); } }
public static void main(String[] args) throws Exception { // 生成测试数据 List<String> list = new ArrayList<String>(); list.add("1001"); list.add("1002"); list.add("1003"); list.add("1"); list.add("2"); list.add("3"); list.add("11"); list.add("12"); list.add("13"); // 整型、字符串、日期都是类似的操作;下面只给出字符串的示范 System.out.println("当前顺序..."); System.out.println(list); Collections.sort(list); System.out.println("默认排序后..."); System.out.println(list); Collections.sort(list, Collections.reverseOrder()); System.out.println("倒序后..."); System.out.println(list); Collections.sort(list, new Str2IntComparator(false)); System.out.println("按整型排序后..."); System.out.println(list); Collections.sort(list, new Str2IntComparator(true)); System.out.println("按整型倒序后..."); System.out.println(list); } }
输出:
当前顺序...
[1001, 1002, 1003, 1, 2, 3, 11, 12, 13]
默认排序后...
[1, 1001, 1002, 1003, 11, 12, 13, 2, 3]
倒序后...
[3, 2, 13, 12, 11, 1003, 1002, 1001, 1]
按整型排序后...
[1, 2, 3, 11, 12, 13, 1001, 1002, 1003]
按整型倒序后...
[1003, 1002, 1001, 13, 12, 11, 3, 2, 1]