1.集合的工具类java.util.Collections下有一个静态方法:sort,可以对List集合进行自然排序(从小到大)但对于sort方法而言,它能比较的是要求可以直接进行比较的类型,所以如果比较的内容无法直接比较需要单独定义比较器 定义元素之间的比较规则
public class SortListDemo2 { public static void main(String[] args) { List<Point> list = new ArrayList<>(); list.add(new Point(5,6)); list.add(new Point(13,87)); list.add(new Point(55,35)); list.add(new Point(9,4)); list.add(new Point(2,1)); list.add(new Point(99,88)); System.out.println(list); /* Collections.sort(List list) 该方法要求List集合中的元素必须是可比较的.判定是否课比较的标准为元素是否实现了接口: java.util.Comparable 当我们使用一个API时,该API反过来要求我们为其修改代码,那么这个API就对我们的程序有侵入性. 侵入性不利于程序后期维护,应当尽量避免. compare:比较 */ // Collections.sort(list); //单独定义比较器(定义Point元素的比较规则),可以采用lambda来对定义器进行缩减 // Comparator<Point> c = new Comparator<Point>() { // /* // compare方法用于定义o1和o2比较大小的规则,并用返回值表达大小关系. // 返回值实现的要求: // 如果返回值>0则表达的是o1>o2 // 如果返回值<0则表达的是o1<o2 // 如果返回值=0则表达的是o1=o2 // */ // public int compare(Point o1, Point o2) { // int olen1 = o1.getX()*o1.getX()+o1.getY()*o1.getY(); // int olen2 = o2.getX()*o2.getX()+o2.getY()*o2.getY(); return olen1-olen2;//升序 // return olen2-olen1;//反过来减就是降序(从大到小) // } // }; // Collections.sort(list,c); // Collections.sort(list,new Comparator<Point>() { // public int compare(Point o1, Point o2) { // int olen1 = o1.getX()*o1.getX()+o1.getY()*o1.getY(); // int olen2 = o2.getX()*o2.getX()+o2.getY()*o2.getY(); // return olen1-olen2;//升序 // } // }); Collections.sort(list,(o1,o2)-> o1.getX()*o1.getX()+o1.getY()*o1.getY()- o2.getX()*o2.getX()-o2.getY()*o2.getY() ); System.out.println(list); } }
二、在list中字符串之间比较的规则为 按照字母的大小和字母的先后顺序进行比较。 当字符串中为其他韩文字时 可以设置一个比较器
public class SortListDemo3 { public static void main(String[] args) { List<String> list = new ArrayList<>(); // list.add("jack"); // list.add("rose"); // list.add("jerry"); // list.add("tom"); // list.add("black"); // list.add("ada"); list.add("苍老师"); list.add("传奇"); list.add("小泽老师"); System.out.println(list); // Collections.sort(list); // Collections.sort(list,(o1,o2)->o1.length()-o2.length()); // Collections.sort(list, Comparator.comparingInt(String::length)); /* JDK8之后,List集合自身提供了sort方法进行排序,sort方法依然需要传入比较器. */ list.sort((o1, o2) -> o1.length()-o2.length()); System.out.println(list); } }