一、Lambda表达式详解
2017-03-31 本文已影响52人
编程界的小学生
1、为什么使用Lambda表达式
Lambda是一个匿名函数,我们可以把Lambda表达式理解为是一段可以传递的代码(将代码像数据一样进行传递)。可以写出更简洁、更灵活的代码。作为一种更紧凑的代码风格,使Java的语言表达能力得到了提升。
2、Lambda表达式代码体验
(1)从匿名类到Lambda的转换
@Test
public void test1() {
//原来写法,实现匿名内部类。
Runnable runnable = new Runnable() {
@Override
public void run() {
System.out.println("Hello");
}
};
runnable.run();
System.out.println("----------------------------------");
//Lambda表达式写法
Runnable runnable2 = () -> System.out.println("Hello");
runnable2.run();
}
(2)原来使用匿名内部类作为参数传递
@Test
public void test() {
//原来写法
TreeSet<String> ts = new TreeSet<>(new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
return Integer.compare(o1.length(), o2.length());
}
});
//Lambda表达式写法
TreeSet<String> ts2 = new TreeSet<>(
(o1, o2) -> Integer.compare(o1.length(), o2.length())
);
}
有没有发现Lambda很方便快捷呢?看不懂没关系,这里只是为了证明Lambda的确很节省代码,开发快速。
3、Lambda表达式语法
package com.chentongwei.java8;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.TreeSet;
import java.util.function.Consumer;
import org.junit.Test;
/**
* 一、Lambds表达式的基础语法:在Java8中引入了一个新的操作符“->”,该操作符成为箭头操作符或Lambda操作符
* 箭头操作符将Lambda表达式拆分成两部分
* 表达式左边:Lambda表达式的参数列表
* 表达式右边:Lambda表达式中所需执行的功能,即Lambda体
*
* 语法格式一:无参数,无返回值 test1()
* () -> System.out.println("Hello Lambda");
*
* 语法格式二:有一个参数,并且无返回值 test2()
* (x) -> System.out.println("x=" + x);
*
* 语法格式三:若只有一个参数,小括号可以省略不写 test2()
* x -> System.out.println("x=" + x);
*
* 语法格式四:有两个以上的参数,有返回值,并且Lambda体中有多条语句 test3()
* Comparator<Integer> com = (x, y) -> {
* System.out.println("函数式接口");
* return Integer.compare(x, y);
* }
*
* 语法格式五:若Lambda体只有一条语句,return和大括号都可以省略不写 test3()
* Comparator<Integer> com = (x, y) -> Integer.compare(x, y);
*
* 语法格式六:Lambda表达式的参数列表的数据类型可以省略不写,因为JVM编译器通过上下文推断出,数据类型,即“类型推断” test4()
* (Integer x, Integer y) -> Integer.compare(x, y);
*
* @author 15620646321@163.com
* @date 2017年3月31日
*/
public class TestLambda2 {
@Test
//只混眼熟,说明lambda很简单。
public void test() {
//原来写法
TreeSet<String> ts = new TreeSet<>(new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
return Integer.compare(o1.length(), o2.length());
}
});
//Lambda表达式写法
TreeSet<String> ts2 = new TreeSet<>(
(o1, o2) -> Integer.compare(o1.length(), o2.length())
);
}
@Test
public void test1() {
Runnable runnable = new Runnable() {
int num = 1; //jdk1.7之前需要强制声明为final的,否则编译错误,1.8默认就是final的。
@Override
public void run() {
System.out.println("num1=====" + num);
}
};
runnable.run();
System.out.println("----------------------------------");
Runnable runnable2 = () -> System.out.println("num2=====");
runnable2.run();
}
@Test
public void test2() {
Consumer<Integer> consumer = (x) -> System.out.println(x);
consumer.accept(1);
System.out.println("-------------------------------------");
Consumer<String> consumer2 = x -> System.out.println(x);
consumer2.accept("Hello");
}
@Test
public void test3() {
Comparator<Integer> comparator2 = new Comparator<Integer>() {
public int compare(Integer o1, Integer o2) {
System.out.println("函数式接口");
return Integer.compare(o1, o2);
}
};
System.out.println("---------------------------------------");
Comparator<Integer> comparator = (x, y) -> {
System.out.println("函数式接口");
return Integer.compare(x, y);
};
}
@Test
public void test4() {
Comparator<Integer> comparator = (x, y) -> Integer.compare(x, y);
}
@Test
public void test5() {
//jdk1.7支持后面不写泛型,自动推断类型
List<String> list = new ArrayList<>();
//jdk1.8 升级了自动推断,如下
show(new HashMap<>());
}
public void show(Map<String, Integer> map) {}
@Test
public void test6() {
//100是第一个参数,后面的lambda是第二个参数(接口)的实现。
Integer num = operation(100, x -> x * x);
System.out.println(num);
System.out.println(operation(100, x -> x + x));
}
public Integer operation(Integer num, Functional mf) {
return mf.getValue(num);
}
}
若有兴趣,欢迎来加入群,【Java初学者学习交流群】:458430385,此群有Java开发人员、UI设计人员和前端工程师。有问必答,共同探讨学习,一起进步!
欢迎关注我的微信公众号【Java码农社区】,会定时推送各种干货:
![](https://img.haomeiwen.com/i4582242/ca4a357ae859b1aa.jpg)