Java 8 Lambda 表达式

/ 语言 / 没有评论 / 340浏览

Lambda 表达式,也可称为闭包,它是推动 Java 8 发布的最重要新特性。 Lambda 允许把函数作为一个方法的参数(函数作为参数传递进方法中)。 使用 Lambda 表达式可以使代码变的更加简洁紧凑。

-----------------来自小马哥的故事

语法

lambda 表达式的语法格式如下:

(parameters) -> expression
或
(parameters) ->{ statements; }

以下是lambda表达式的重要特征:

Lambda 表达式实例

在 Java8Tester.java 文件输入以下代码: Java8Tester.java 文件

    public class Java8Tester {
       public static void main(String args[]){
      Java8Tester tester = new Java8Tester();
    
      // 类型声明
      MathOperation addition = (int a, int b) -> a + b;
    
      // 不用类型声明
      MathOperation subtraction = (a, b) -> a - b;
    
      // 大括号中的返回语句
      MathOperation multiplication = (int a, int b) -> { return a * b; };
    
      // 没有大括号及返回语句
      MathOperation division = (int a, int b) -> a / b;
    
      System.out.println("10 + 5 = " + tester.operate(10, 5, addition));
      System.out.println("10 - 5 = " + tester.operate(10, 5, subtraction));
      System.out.println("10 x 5 = " + tester.operate(10, 5, multiplication));
      System.out.println("10 / 5 = " + tester.operate(10, 5, division));
    
      // 不用括号
      GreetingService greetService1 = message ->
      System.out.println("Hello " + message);
    
      // 用括号
      GreetingService greetService2 = (message) ->
      System.out.println("Hello " + message);
    
      greetService1.sayMessage("Runoob");
      greetService2.sayMessage("Google");
       }
    
       interface MathOperation {
      int operation(int a, int b);
       }
    
       interface GreetingService {
      void sayMessage(String message);
       }
    
       private int operate(int a, int b, MathOperation mathOperation){
      return mathOperation.operation(a, b);
       }
    }

执行以上脚本,输出结果为:

$ javac Java8Tester.java 
$ java Java8Tester
10 + 5 = 15
10 - 5 = 5
10 x 5 = 50
10 / 5 = 2
Hello Runoob
Hello Google

使用 Lambda 表达式需要注意以下两点: Lambda 表达式主要用来定义行内执行的方法类型接口,例如,一个简单方法接口。在上面例子中,我们使用各种类型的Lambda表达式来定义MathOperation接口的方法。然后我们定义了sayMessage的执行。 Lambda 表达式免去了使用匿名方法的麻烦,并且给予Java简单但是强大的函数化的编程能力。

变量作用域

lambda 表达式只能引用 final 或 final 局部变量,这就是说不能在 lambda 内部修改定义在域外的变量,否则会编译错误。 在 Java8Tester.java 文件输入以下代码: Java8Tester.java 文件

public class Java8Tester {
 
   final static String salutation = "Hello! ";
   
   public static void main(String args[]){
  GreetingService greetService1 = message -> 
  System.out.println(salutation + message);
  greetService1.sayMessage("Runoob");
   }

   interface GreetingService {
  void sayMessage(String message);
   }
}

执行以上脚本,输出结果为:

$ javac Java8Tester.java 
$ java Java8Tester
Hello! Runoob

在弄一个简单的例子

两个集合合并到一块并去重



    public static void main(String[] args) {


        Ren ren1 = new Ren();
        ren1.setAge(1);
        ren1.setName("测试1");
        Ren ren2 = new Ren();
        ren2.setAge(2);
        ren2.setName("测试2");
        List<Ren>  list1 =  Arrays.asList(ren1,ren2);

        Ren ren3 = new Ren();
        ren3.setAge(3);
        ren3.setName("测试3");
        Ren ren4 = new Ren();
        ren4.setAge(4);
        ren4.setName("测试4");
//        List<Ren>  list2 =  new ArrayList<>();
        List<Ren>  list2 =  Arrays.asList(ren3,ren4);
        List<Ren> renList = Stream.of(list1, list1).flatMap(Collection::stream).distinct().collect(Collectors.toList());
        renList.forEach(System.out::println);





    }
    static class  Ren{
        private String name;
        private Integer age;

        @Override
        public String toString() {
            return "Ren{" +
                    "name='" + name + '\'' +
                    ", age=" + age +
                    '}';
        }

        public String getName() {
            return name;
        }

        public void setName(String name) {
            this.name = name;
        }

        public Integer getAge() {
            return age;
        }

        public void setAge(Integer age) {
            this.age = age;
        }
    }


集合中的对象多个字段排序


    //排序
    public  List<CurriculumRespDTO> getSortList1(List<CurriculumRespDTO> list) {
        Collections.sort(list,(o1, o2)-> (o1.getScheduleDay() + o1.getStartTime() ).compareTo(o2.getScheduleDay() + o2.getStartTime())    );
        return list;
    }