今天写到关于list更具一套规则重新排序的问题。具体需求是有一个List对象,元素是Media类型,Media类有一个mediaName属性,还有一个List<String>,存储一组文件名,现在要求Media的list更具文件名排序,要求文件名的顺序和List<String>存储的一致。
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<String>文件名的方式,进行排序的操作,但是未免有些繁琐。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
}
还有一种方式可以将排序规则作为入参放在方法中,这样可以引入对象外的其他参数。
(medias, new Comparator<MediaPojo>() {
public int compare(MediaPojo o1, MediaPojo o2){
Integer i1 = (()); //order表示文件名列表,在方法体外引入
Integer i2 = (());
return (i2);
}
});
但是在JDK1.8中List增加了sort方法,入参为排序规则,实现也很简单
(new Comparator<MediaPojo>() {
public int compare(MediaPojo o1, MediaPojo o2){
Integer i1 = (());
Integer i2 = (());
return (i2);
}
});