• 【Java】使用Lambda排序集合


    下面是Java lambda表达式的简单例子:

    // 1. 不需要参数,返回值为 5  
    () -> 5  
      
    // 2. 接收一个参数(数字类型),返回其2倍的值  
    x -> 2 * x  
      
    // 3. 接受2个参数(数字),并返回他们的差值  
    (x, y) -> x – y  
      
    // 4. 接收2个int型整数,返回他们的和  
    (int x, int y) -> x + y  
      
    // 5. 接受一个 string 对象,并在控制台打印,不返回任何值(看起来像是返回void)  
    (String s) -> System.out.print(s)

    在Java中,Comparator 类被用来排序集合。 在下面的例子中,我们将根据球员的 name, surname, name 长度 以及最后一个字母。 和前面的示例一样,先使用匿名内部类来排序,然后再使用lambda表达式精简我们的代码。
    在第一个例子中,我们将根据name来排序list。 使用旧的方式,代码如下所示:

    String[] players = {"Rafael Nadal", "Novak Djokovic",   
        "Stanislas Wawrinka", "David Ferrer",  
        "Roger Federer", "Andy Murray",  
        "Tomas Berdych", "Juan Martin Del Potro",  
        "Richard Gasquet", "John Isner"};  
       
    // 1.1 使用匿名内部类根据 name 排序 players  
    Arrays.sort(players, new Comparator<String>() {  
        @Override  
        public int compare(String s1, String s2) {  
            return (s1.compareTo(s2));  
        }  
    });

    使用lambdas,可以通过下面的代码实现同样的功能:

    // 1.2 使用 lambda expression 排序 players  
    Comparator<String> sortByName = (String s1, String s2) -> (s1.compareTo(s2));  
    Arrays.sort(players, sortByName);  
      
    // 1.3 也可以采用如下形式:  
    Arrays.sort(players, (String s1, String s2) -> (s1.compareTo(s2)));  

    其他的排序如下所示。 和上面的示例一样,代码分别通过匿名内部类和一些lambda表达式来实现Comparator :

    // 1.1 使用匿名内部类根据 surname 排序 players  
    Arrays.sort(players, new Comparator<String>() {  
        @Override  
        public int compare(String s1, String s2) {  
            return (s1.substring(s1.indexOf(" ")).compareTo(s2.substring(s2.indexOf(" "))));  
        }  
    });  
      
    // 1.2 使用 lambda expression 排序,根据 surname  
    Comparator<String> sortBySurname = (String s1, String s2) ->   
        ( s1.substring(s1.indexOf(" ")).compareTo( s2.substring(s2.indexOf(" ")) ) );  
    Arrays.sort(players, sortBySurname);  
      
    // 1.3 或者这样,怀疑原作者是不是想错了,括号好多...  
    Arrays.sort(players, (String s1, String s2) ->   
          ( s1.substring(s1.indexOf(" ")).compareTo( s2.substring(s2.indexOf(" ")) ) )   
        );  
      
    // 2.1 使用匿名内部类根据 name lenght 排序 players  
    Arrays.sort(players, new Comparator<String>() {  
        @Override  
        public int compare(String s1, String s2) {  
            return (s1.length() - s2.length());  
        }  
    });  
      
    // 2.2 使用 lambda expression 排序,根据 name lenght  
    Comparator<String> sortByNameLenght = (String s1, String s2) -> (s1.length() - s2.length());  
    Arrays.sort(players, sortByNameLenght);  
      
    // 2.3 or this  
    Arrays.sort(players, (String s1, String s2) -> (s1.length() - s2.length()));  
      
    // 3.1 使用匿名内部类排序 players, 根据最后一个字母  
    Arrays.sort(players, new Comparator<String>() {  
        @Override  
        public int compare(String s1, String s2) {  
            return (s1.charAt(s1.length() - 1) - s2.charAt(s2.length() - 1));  
        }  
    });  
      
    // 3.2 使用 lambda expression 排序,根据最后一个字母  
    Comparator<String> sortByLastLetter =   
        (String s1, String s2) ->   
            (s1.charAt(s1.length() - 1) - s2.charAt(s2.length() - 1));  
    Arrays.sort(players, sortByLastLetter);  
      
    // 3.3 or this  
    Arrays.sort(players, (String s1, String s2) -> (s1.charAt(s1.length() - 1) - s2.charAt(s2.length() - 1)));
  • 相关阅读:
    Eclipse EE 3.6 failed to create the java virtual machine 解决
    [收藏]家用三线插座(220V单相)正确接线方法
    Java设计模式 Design Pattern:包装模式 Decorator Pattern
    MIME 类型列表
    面试题参考
    循环队列的运用求K阶斐波那契序列
    加密技术仿射密码
    面试题集锦_1
    栈的运用(5)转换逆波兰式
    栈的运用(6)逆波兰式求值
  • 原文地址:https://www.cnblogs.com/jxd283465/p/11759298.html
Copyright © 2020-2023  润新知