第一种是list中的对象实现Comparable接口,如下:
/*** 根据order对User排序*/public class Usuario implementa Comparable <usuario> { nombre de cadena privada; orden de enteros privados; public String getName() { devolver nombre; } public void setName (nombre de cadena) { this.name = nombre; } público entero getOrder() { orden de devolución; } public void setOrder (orden entero) { this.order = orden; } public int compareTo(Usuario arg0) { return this.getOrder().compareTo(arg0.getOrder()); }} </usuario>
测试一下:
prueba de clase pública {public static void main(String[] args) { Usuario usuario1 = nuevo Usuario(); usuario1.setName("a"); usuario1.setOrder(1); Usuario usuario2 = nuevo Usuario(); usuario2.setName("b"); usuario2.setOrder(2); Lista <usuario> lista = new ArrayList <usuario> (); // Agregar usuario2 y agregar usuario1 list.add(user2); lista.add(usuario1); Colecciones.sort(lista); for(Usuario u: lista){ System.out.println(u.getName()); } }} </usuario> </usuario>
输出结果如下
a
b
第二种方法是根据Collections.sort重载方法来实现,例如:
/*** 根据order对User排序*/public class Usuario { //此处无需实现Comparable接口 nombre de cadena privada; orden de enteros privados; public String getName() { devolver nombre; } public void setName (nombre de cadena) { this.name = nombre; } público entero getOrder() { orden de devolución; } public void setOrder (orden entero) { this.order = orden; }}
主类中这样写即可:
prueba de clase pública {public static void main(String[] args) { Usuario usuario1 = nuevo Usuario(); usuario1.setName("a"); usuario1.setOrder(1); Usuario usuario2 = nuevo Usuario(); usuario2.setName("b"); usuario2.setOrder(2); Lista <usuario> lista = new ArrayList <usuario> (); lista.add(usuario2); lista.add(usuario1); Collections.sort(list,new Comparator <usuario> (){ public int compare(Usuario arg0, Usuario arg1) { return arg0.getOrder().compareTo(arg1.getOrder()); } }); for(Usuario u: lista){ System.out.println(u.getName()); } }} </usuario> </usuario> </usuario>
输出结果如下
a
b
前者代码结构简单,但是只能根据固定的属性排序,后者灵活,可以临时指定排序项,但是代码不够简洁
多字段的场合:
Collections.sort(list,new Comparator <usuario> (){ public int compare(Usuario arg0, Usuario arg1) { // 第一次比较专业 int i = arg0.getOrder().compareTo(arg1.getOrder()); //如果专业相同则进行第二次比较 if(i==0){// 第二次比较 int j=arg0.getXXX().compareTo(arg1.getXXX());//如果学制相同则返回按年龄排序 if(j==0){ return arg0.getCCC().compareTo(arg1.getCCC() } return j } return i; </usuario>
Colección 以上内容就是小编给大家介绍有关用Java集合中的s.sort方法如何对list排序(两种方法),希望对大家有所帮助。