当前位置:   article > 正文

简单使用lambda表达式_一个方法接一个方法的代码叫什么风格

一个方法接一个方法的代码叫什么风格

目录

什么是lambda表达式?

 下面先来个简单案例:

简化lambda表达式:

总结:

语法格式一 :无参,无返回值

语法格式二: :Lambda 需要一个参数,但是没有返回值

语法格式三 : 数据类型可以省略

语法格式四: :Lambda 若只需要一个参数时, 参数的小括号可以省略

语法格式五: :Lambda 需要两个或以上的参数,多条执行语句,并且可以有返回值

语法格式六 :当 当 Lambda 体只有 一条, 语句时,return 号 与大括号 若有,都可以省略

然后下面说下函数式接口:

简单使用lambda表达式使用四大函数式接口:

 方法引用与构造器引用


什么是lambda表达式?

Lambda 是一个 匿名函数,我们可以把 Lambda 表达式理解为是 一段可以传递的代码(将代码像数据一样进行传递)。

使用它可以写出更简洁、更灵活的代码。作为一种更紧凑的代码风格,使Java的语言表达能力得到了提升

Lambda 表达式:在Java 8 语言中引入的一种新的语法元素和操作符。这个操作符为 “->” , 该操作符被称为 Lambda 操作符或 箭 头操作符。

它将 Lambda 分为两个部分:左侧:指定了 Lambda 表达式需要的参 参 数 列表: 右侧:指定了 Lambda 体 ,是抽象方法的实现逻辑,也即Lambda 表达式要执行的功能

 下面先来个简单案例:

  1. package com.chen.lambda;
  2. /*
  3. * 推导lambda表达式
  4. * */
  5. public class TestLambda {
  6. //3.静态内部类
  7. static class Like2 implements ILike{
  8. @Override
  9. public void lambda() {
  10. System.out.println("I like lambda2");
  11. }
  12. }
  13. public static void main(String[] args) {
  14. ILike like=new Like();
  15. like.lambda();
  16. like=new Like2();
  17. like.lambda();
  18. //4.局部内部类
  19. class Like3 implements ILike{
  20. @Override
  21. public void lambda() {
  22. System.out.println("I like lambda3");
  23. }
  24. }
  25. like=new Like3();
  26. like.lambda();
  27. //5.匿名内部类,没有类的名称,必须帮助接口或者父类
  28. like =new ILike() {
  29. @Override
  30. public void lambda() {
  31. System.out.println("I like lambda4");
  32. }
  33. };
  34. like.lambda();
  35. //6.用lambda简化
  36. like=()->{
  37. System.out.println("I like lambda5");
  38. };
  39. like.lambda();
  40. }
  41. }
  42. //1.定义一个函数式接口
  43. interface ILike{
  44. void lambda();
  45. }
  46. //2.实现类
  47. class Like implements ILike{
  48. @Override
  49. public void lambda() {
  50. System.out.println("I like lambda");
  51. }
  52. }

简化lambda表达式:

  1. package com.chen.lambda;
  2. public class TestLambda2 {
  3. static class Love implements ILove{
  4. @Override
  5. public void love(int a) {
  6. System.out.println("I Love you -->"+a);
  7. }
  8. }
  9. public static void main(String[] args) {
  10. ILove love=new Love();
  11. love.love(2);
  12. //匿名内部类
  13. ILove love2=new ILove() {
  14. @Override
  15. public void love(int a) {
  16. System.out.println("I Love you -->"+a);
  17. }
  18. };
  19. love2.love(5);
  20. //lambda表达式简化
  21. ILove love3=(int a)->{
  22. System.out.println("I Love you -->"+a);
  23. };
  24. love3.love(520);
  25. //简化1.参数类型
  26. ILove love4=(a)->{
  27. System.out.println("I Love you -->"+a);
  28. };
  29. love4.love(520);
  30. //简化2.简化括号
  31. ILove love5=a ->{
  32. System.out.println("I Love you -->" + a);
  33. };
  34. love5.love(520);
  35. //简化3.去掉花括号
  36. ILove love6=a ->
  37. System.out.println("I Love you -->" + a);
  38. love6.love(520);
  39. //总结:
  40. //lambda表达式只能有一行代码的情况下才能称为一行,如果有多行,那么就用代码块包裹
  41. //前提是接口为函数式接口
  42. //多个参数也可以去掉参数类型,要去掉就都去掉,必须加上括号
  43. ILove2 love7=(a,b) ->
  44. a*b;
  45. System.out.println(love7.love(7,8));
  46. }
  47. }
  48. interface ILove{
  49. void love(int a);
  50. }
  51. interface ILove2{
  52. int love(int a,int b);
  53. }
  54. class Love implements ILove{
  55. @Override
  56. public void love(int a) {
  57. System.out.println("I Love You");
  58. }
  59. }

总结:

语法格式一 :无参,无返回值

  Runnable runnable1=()->System.out.println("ddd");

语法格式二: :Lambda 需要一个参数,但是没有返回值

  1. Consumer<String> con=(String str) -> {System.out.println(str);};
  2. //输出
  3. con.accept("aaa");

语法格式三 : 数据类型可以省略

​Consumer<String> con=(str) -> {System.out.println(str);};

语法格式四: :Lambda 若只需要一个参数时, 参数的小括号可以省略

Consumer<String> con=str -> {System.out.println(str);};

语法格式五: :Lambda 需要两个或以上的参数,多条执行语句,并且可以有返回值

  1. Comparator<Integer> com=(x, y) -> {
  2. System.out.println("实现函数式接口方法");
  3. return Integer.compare(x,y);
  4. };
  5. //输出结果
  6. System.out.println(com.compare(11,10));

语法格式六 :当 当 Lambda 体只有 一条, 语句时,return 号 与大括号 若有,都可以省略

 Comparator<Integer> com=(x, y) -> Integer.compare(x,y);
     

上述 Lambda 表达式中的参数类型都是由编译器推断得出的。Lambda
表达式中无需指定类型,程序依然可以编译,这是因为 javac 根据程序
的上下文,在后台推断出了参数的类型。Lambda 表达式的类型依赖于
上下文环境,是由编译器推断出来的。这就是所谓的“类型推断”

然后下面说下函数式接口:

只包含一个抽象方法的接口,称为 函数式接口。
1.你可以通过 Lambda 表达式来创建该接口的对象。(若 Lambda 表达式抛出一个受检异常(即:非运行时异常),那么该异常需要在目标接口的抽象方法上进行声明)。
2.我们可以在一个接口上使用 @FunctionalInterface 注解,这样做可以检查它是否是一个函数式接口。同时 javadoc 也会包含一条声明,说明这个接口是一个函数式接口。

在Java8中,有所不同。在
Java8中,Lambda表达式是对象,而不是函数,它们必须依附于一类特别的对象类型——函数式接口。
简单的说,在Java8中,Lambda表达式就是一个函数式接口的实例。这就是Lambda表达式和函数式接口的关系。

也就是说,只要一个对象是函数式接口的实例,那么该对象就可以用Lambda表达式来表示

 所以以前用匿名实现类表示的现在都可以用Lambda表达式来写

 

简单使用lambda表达式使用四大函数式接口:

代码案例:

  1. //Consumer<T> 消费型接口:
  2. @Test
  3. public void test1(){
  4. happy(10000,(m) -> System.out.println("今天消费了:"+(m+m)));
  5. }
  6. public void happy(double money, Consumer<Double> con){
  7. con.accept(money);
  8. }
  9. //Supplier 供给型接口:
  10. @Test
  11. public void test2(){
  12. List<Integer> numList= getNumList(10,() ->(int)(Math.random()*100));
  13. for(Integer num:numList){
  14. System.out.println(num);
  15. }
  16. }
  17. //需求:产生指定个整数,并放入到集合中
  18. public List<Integer> getNumList(int num, Supplier<Integer> sup){
  19. List<Integer> list=new ArrayList<>();
  20. for(int i=0;i<num;i++){
  21. Integer n=sup.get();
  22. list.add(n);
  23. }
  24. return list;
  25. }
  26. //Function<T ,R> 函数型接口
  27. @Test
  28. public void test3(){
  29. String newStr = strHandler("\t\t\t 我爱爱学习",(str) -> str.trim());
  30. System.out.println(newStr);
  31. String subStr = strHandler("\t\t\t 我爱爱学习",(str)-> str.substring(2,5));
  32. System.out.println(subStr);
  33. }
  34. //需求:用于处理字符串
  35. public String strHandler(String str, Function<String,String> fun){
  36. return fun.apply(str);
  37. }
  38. //Predicate<T> 断言型接口
  39. @Test
  40. public void test4(){
  41. List<java.lang.String> list= Arrays.asList("hello","hello2","hello3");
  42. List<String> strList=filterStr(list,(s) -> s.length()>5);
  43. for(String str:strList){
  44. System.out.println(str);
  45. }
  46. }
  47. //需求:将满足条件的字符串,放入集合中
  48. public List<String> filterStr(List<String> list, Predicate<String> pre){
  49. List<String> strList=new ArrayList<>();
  50. for(String str:list){
  51. if(pre.test(str)){
  52. strList.add(str);
  53. }
  54. }
  55. return strList;
  56. }

 方法引用与构造器引用

方法引用

当要传递给Lambda体的操作,已经有实现的方法了,可以使用方法引用!
1.方法引用可以看做是Lambda表达式深层次的表达。换句话说,方法引用就是Lambda表达式,也就是函数式接口的一个实例,通过方法的名字来指向
一个方法,可以认为是Lambda表达式的一个语法糖。
2.要求:实现接口的抽象方法的参数列表和返回值类型,必须与方法引用的方法的参数列表和返回值类型保持一致!

3.格式:使用操作符 “::” 将类(或对象) 与 方法名分隔开来。
 如下三种主要使用情况:
 对象:: 实例方法名
 类 :: 静态方法名
 类 :: 实例方法

例如:

  1. Consumer<String> con=(x) -> System.out.println(x);
  2. //相当于
  3. Consumer<String> con=System.out::println;
  1. Comparator<Integer> c=(x,y) -> Integer.compare(x,y);
  2. //相当于
  3. Comparator<Integer> c2=Integer::compare;
  1. BiPredicate<String,String> bp=(x,y) -> x.equals(y);
  2. //相当于
  3. BiPredicate<String,String> bp1=String::equals;
  4. //输出结果
  5. System.out.println(bp1.test("s","t"));

构造器 引用

格式: ClassName::new
与函数式接口相结合,自动与函数式接口中方法兼容。
可以把构造器引用赋值给定义的方法,要求构造器参数列表要与接口中抽象
方法的参数列表一致!且方法的返回值即为构造器对应类的对象

  1. Function<Integer,Myclass> fun=(n) -> new Myclass(n);
  2. //相当于
  3. Function<Integer,Myclass> fun=Myclass::new;

数组引用

  1. Function<Integer,Integer[]> fun3=(n) -> new Integer[n];
  2. //相当于
  3. Function<Integer,Integer[]> fun4=Integer[]::new;
  4. System.out.println(fun4.apply(1555).length);

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/在线问答5/article/detail/1006262
推荐阅读
相关标签
  

闽ICP备14008679号