List中的排序sort()方法与Collection.sort(List)方法

今天写到关于list更具一套规则重新排序的问题。具体需求是有一个List对象,元素是Media类型,Media类有一个mediaName属性,还有一个List,存储一组文件名,现在要求Media的list更具文件名排序,要求文件名的顺序和List存储的一致。

Media类:

public class Media implements Serializable {
	private static final long serialVersionUID = 1L;
    private String mediaId;
    private String mediaName;
    private String mediaSize;
    private String objectType;
    private String objectId;
    private String mediaType;
    //getter,setter
}

这种排序当然可以通过新建一个List对象,然后遍历List文件名的方式,进行排序的操作,但是未免有些繁琐。java为我们提供了排序的方式。

在JDK1.7中一般使用工具类Collections(注意区分集合几口Collection),来对集合进行排序,集合中的对象类必须实现Comparable接口的compare方法,用于比较两个对象大小,但是这种方法只能通过比较内部的属性的大小来进行逻辑上的判断,通常Integer等装箱类和String都实现了compare方法。以Integer的为例:

public static int compare(int x, int y) {    
        return (x < y) ? -1 : ((x == y) ? 0 : 1);//x>y返回1,等于返回0,小于返回-1
    }

还有一种方式可以将排序规则作为入参放在Collections.sort方法中,这样可以引入对象外的其他参数。

Collections.sort(medias, new Comparator() {
                            public int compare(MediaPojo o1, MediaPojo o2){
                                Integer i1 = order.indexOf(o1.getMediaName()); //order表示文件名列表,在方法体外引入
                                Integer i2 = order.indexOf(o2.getMediaName());
                                return i2.compareTo(i2);
                            }
                        });

但是在JDK1.8中List增加了sort方法,入参为排序规则,实现也很简单

medias.sort(new Comparator() {
                            public int compare(MediaPojo o1, MediaPojo o2){
                                Integer i1 = order.indexOf(o1.getMediaName());
                                Integer i2 = order.indexOf(o2.getMediaName());
                                return i2.compareTo(i2);
                            }
                        });




你可能感兴趣的:(java)