目录
Java8新特性
Lambda表达式
函数式(Functional)接口
Java内置四大核心函数式接口
方法引用
构造器引用、数组引用
Java8新特性
Lambda表达式
Lambda 是一个匿名函数,我们可以把 Lambda 表达式理解为是一段可以
传递的代码(将代码像数据一样进行传递)。使用它可以写出更简洁、更
灵活的代码。作为一种更紧凑的代码风格,使Java的语言表达能力得到了
提升。
代码举例
public class LambdaTest {
@Test
public void test1(){
Runnable r1 = new Runnable() {
@Override
public void run() {
System.out.println("我爱北京天安门");
}
};
r1.run();
System.out.println("---------------------");
//Lambda表达式
Runnable r2 = () -> System.out.println("我爱北京故宫");
r2.run();
}
@Test
public void test2(){
Comparator com1 = new Comparator() {
@Override
public int compare(Integer o1, Integer o2) {
return Integer.compare(o1,o2);
}
};
int compare1 = com1.compare(12,21);
System.out.println(compare1); //-1
System.out.println("-----------------------");
//Lambdad表达式写法
Comparator com2 = (o1,o2) -> Integer.compare(o1,o2);
int compare2 = com2.compare(12,21);
System.out.println(compare2); //-1
System.out.println("-----------------------");
//方法引用
Comparator com3 = Integer :: compare;
int compare3 = com2.compare(12,21);
System.out.println(compare3); //-1
}
}
代码实现
public class LambdaTest1 {
//语法格式一:无参,无返回值
@Test
public void test1(){
Runnable r1 = new Runnable() {
@Override
public void run() {
System.out.println("我爱北京天安门");
}
};
r1.run();
System.out.println("---------------------");
Runnable r2 = () -> {
System.out.println("我爱北京故宫");
};
r2.run();
}
//语法格式二:Lambda 需要一个参数,但是没有返回值。
@Test
public void test2(){
Consumer con = new Consumer() {
@Override
public void accept(String s) {
System.out.println("s");
}
};
con.accept("谎言和誓言的区别是什么?");
System.out.println("-----------------------");
Consumer con1 = (String s) ->{
System.out.println("s");
};
con1.accept("一个是听的人当真了,一个是说的人当真了");
}
//语法格式三:数据类型可以省略,因为可由编译器推断得出,称为“类型推断”
@Test
public void test3(){
Consumer con1 = (String s) ->{
System.out.println("s");
};
con1.accept("一个是听的人当真了,一个是说的人当真了");
System.out.println("-----------------------");
Consumer con2 = (s) ->{ //变化
System.out.println("s");
};
con2.accept("一个是听的人当真了,一个是说的人当真了");
//--------------------------------------------
ArrayList list = new ArrayList<>(); //类型推断
int[] arr1 = new int[]{1,2,3};
int[] arr2 = {1,2,3}; //类型推断
}
//语法格式四:Lambda 若只需要一个参数时,参数的小括号可以省略
@Test
public void test4(){
Consumer con1 = (s) ->{ //变化
System.out.println("s");
};
con1.accept("一个是听的人当真了,一个是说的人当真了");
System.out.println("-----------------------");
Consumer con2 = s ->{ //变化
System.out.println("s");
};
con2.accept("一个是听的人当真了,一个是说的人当真了");
}
//语法格式五:Lambda 需要两个或以上的参数,多条执行语句,并且可以有返回值
@Test
public void test5(){
Comparator com1 = new Comparator() {
@Override
public int compare(Integer o1, Integer o2) {
System.out.println(o1);
System.out.println(o2);
return o1.compareTo(o2);
}
};
System.out.println(com1.compare(12,21));
System.out.println("-----------------------");
Comparator com2 = (o1,o2) -> {
System.out.println(o1);
System.out.println(o2);
return o1.compareTo(o2);
};
System.out.println(com2.compare(12,21));
}
//语法格式六:当 Lambda 体只有一条语句时,return 与大括号若有,都可以省略
@Test
public void test6(){
Comparator com1 = (o1,o2) -> {
return o1.compareTo(o2);
};
System.out.println(com1.compare(12,21));
System.out.println("-----------------------");
Comparator com2 = (o1,o2) -> o1.compareTo(o2);
System.out.println(com2.compare(12,21));
}
@Test
public void Test7(){
Consumer con1 = s ->{
System.out.println("s");
};
con1.accept("一个是听的人当真了,一个是说的人当真了");
System.out.println("-----------------------");
Consumer con2 = s -> System.out.println("s");
con1.accept("一个是听的人当真了,一个是说的人当真了");
}
}
函数式(Functional)接口
只包含一个抽象方法的接口,称为函数式接口。
你可以通过 Lambda 表达式来创建该接口的对象。(若 Lambda 表达式
抛出一个受检异常(即:非运行时异常),那么该异常需要在目标接口的抽
象方法上进行声明)。
我们可以在一个接口上使用 @FunctionalInterface 注解,这样做可以检
查它是否是一个函数式接口。同时 javadoc 也会包含一条声明,说明这个
接口是一个函数式接口。
在java.util.function包下定义了Java 8 的丰富的函数式接口
//自定义函数式接口
@FunctionalInterface
public interface MyInterface {
void method1();
}
Java内置四大核心函数式接口
代码
public class LambdaTest2 {
@Test//例子1
public void test1(){
happyTime(500, new Consumer() {
@Override
public void accept(Double aDouble) {
System.out.println("去天上人间买了瓶娃哈哈,价格为"+aDouble);
}
});
System.out.println("-------------");
//Lambda表达式
happyTime(500,aDouble-> System.out.println("去天上人间买了瓶娃哈哈,价格为"+aDouble));
}
//消费形接口
public void happyTime(double money, Consumer con){
con.accept(money);
}
@Test//例子2
public void Test2(){
List list = Arrays.asList("北京","南京","天津","东京","西京","普京","晶晶");
List filterStrs = filterString(list, new Predicate() {
@Override
public boolean test(String s) {
return s.contains("京");
}
});
System.out.println(filterStrs);
System.out.println("-------------");
//Lambda表达式
List filterStrs1 = filterString(list,s ->s.contains("京"));
}
//断定型接口:根据给定的规则,过滤集合中的字符串。此规则由Predicate方法决定
public List filterString(List list, Predicate pre){
ArrayList filterString = new ArrayList<>();
for(String s: list){
if(pre.test(s)){ //Predicate接口中的方法 test
filterString.add(s);
}
}
return filterString;
}
}
方法引用
代码
public class MethodRefTest {
// 情况一:对象 :: 实例方法
//Consumer中的void accept(T t)
//PrintStream中的void println(T t)
@Test
public void test1() {
Consumer con1 = str -> System.out.println(str);
con1.accept("北京");
System.out.println("----------------------");
PrintStream ps = System.out;
Consumer con2 =ps ::println;
con2.accept("北京");
}
//Supplier中的T get()
//Employee中的String getName()
@Test
public void test2() {
Employee emp = new Employee(1001,"tom",23,5600);
Supplier sup1 = () -> emp.getName();
System.out.println(sup1.get());
System.out.println("----------------------");
Supplier sup2 = emp :: getName;
System.out.println(sup2.get());
}
// 情况二:类 :: 静态方法
//Comparator中的int compare(T t1,T t2)
//Integer中的int compare(T t1,T t2)
@Test
public void test3() {
Comparator com1 = (t1,t2) -> Integer.compare(t1,t2);
System.out.println(com1.compare(12,21));
System.out.println("----------------------");
Comparator com2 = Integer :: compare;
System.out.println(com2.compare(12,21));
}
//Function中的R apply(T t)
//Math中的Long round(Double d)
@Test
public void test4() {
Function func = new Function() {
@Override
public Long apply(Double d) {
return Math.round(d);
}
};
System.out.println("----------------------");
Function func1 = d -> Math.round(d);
System.out.println(func1.apply(12.3));
System.out.println("----------------------");
Function func2 = Math :: round;
System.out.println(func2.apply(12.3));
}
// 情况三:类 :: 实例方法 (有难度)
// Comparator中的int comapre(T t1,T t2)
// String中的int t1.compareTo(t2)
@Test
public void test5() {
Comparator com1 = (s1,s2) -> s1.compareTo(s2);
System.out.println(com1.compare("abc","abd"));
System.out.println("----------------------");
Comparator com2 = String :: compareTo;
System.out.println(com2.compare("abc","abm"));
}
//BiPredicate中的boolean test(T t1, T t2);
//String中的boolean t1.equals(t2)
@Test
public void test6() {
BiPredicate pre1 = (s1,s2) -> s1.equals(s2);
System.out.println(pre1.test("abc","abc"));
System.out.println("----------------------");
BiPredicate pre2 = String :: equals;
System.out.println(pre2.test("abc","abd"));
}
// Function中的R apply(T t)
// Employee中的String getName();
@Test
public void test7() {
Employee employee = new Employee(1001, "Jerry", 23, 6000);
Function fun1 = e ->e.getName();
System.out.println(fun1.apply(employee));
System.out.println("----------------------");
Function fun2 = Employee :: getName;
System.out.println(fun2);
}
}



