Lambda表达式
语法:
语法格式一:无参,无返回值
package com.cy.java;
import jdk.internal.util.xml.impl.ReaderUTF16;
public class LambdaTest {
public static void main(String[] args) {
Runnable r1= new Runnable() {
@Override
public void run() {
System.out.println("我爱北京天安门");
}
};
r1.run();
Runnable r2= () -> System.out.println("we are world");
r2.run();
}
}
语法格式二:Lambda 需要一个参数,但是没有返回值。
@Test
public void test2(){
Consumer<String> con = new Consumer<String>() {
@Override
public void accept(String s) {
System.out.println(s);
}
};
con.accept("谎言和誓言的区别是什么?");
System.out.println("*******************");
Consumer<String> con1 = (String s) -> {
System.out.println(s);
};
con1.accept("一个是听得人当真了,一个是说的人当真了");
}
语法格式三:数据类型可以省略,因为可由编译器推断得出,称为“类型推断”
@Test
public void test3(){
Consumer<String> con1 = (String s) -> {
System.out.println(s);
};
con1.accept("一个是听得人当真了,一个是说的人当真了");
System.out.println("*******************");
Consumer<String> con2 = (s) -> {
System.out.println(s);
};
con2.accept("一个是听得人当真了,一个是说的人当真了");
}
语法格式四:Lambda 若只需要一个参数时,参数的小括号可以省略
@Test
public void test5(){
Consumer<String> con1 = (s) -> {
System.out.println(s);
};
con1.accept("一个是听得人当真了,一个是说的人当真了");
System.out.println("*******************");
Consumer<String> con2 = s -> {
System.out.println(s);
};
con2.accept("一个是听得人当真了,一个是说的人当真了");
}
语法格式五:Lambda 需要两个或以上的参数,多条执行语句,并且可以有返回值
@Test
public void test6(){
Comparator<Integer> com1 = new Comparator<Integer>() {
@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<Integer> com2 = (o1,o2) -> {
System.out.println(o1);
System.out.println(o2);
return o1.compareTo(o2);
};
System.out.println(com2.compare(12,6));
}
语法格式六:当 Lambda 体只有一条语句时,return 与大括号若有,都可以省略
@Test
public void test7(){
Comparator<Integer> com1 = (o1,o2) -> {
return o1.compareTo(o2);
};
System.out.println(com1.compare(12,6));
System.out.println("*****************************");
Comparator<Integer> com2 = (o1,o2) -> o1.compareTo(o2);
System.out.println(com2.compare(12,21));
}
@Test
public void test8(){
Consumer<String> con1 = s -> {
System.out.println(s);
};
con1.accept("一个是听得人当真了,一个是说的人当真了");
System.out.println("*****************************");
Consumer<String> con2 = s -> System.out.println(s);
con2.accept("一个是听得人当真了,一个是说的人当真了");
}
}
格式:
(o1,o2) -> Integer.compare(o1,o2);
总结:
(o1,o2) -> Integer.compare(o1,o2);
Lambda表达式的本质
作为函数式接口的实例
函数式接口
- 如果一个接口中,只声明了一个抽象方法,则此接口就称为函数式接口。
- 我们可以在一个接口上使用 @FunctionalInterface 注解, 这样做可以检查它是否是一个函数式接口。
- Consumer接口
public class LambdaTest2 {
@Test
public void test1(){
happyTime(500, new Consumer<Double>() {
@Override
public void accept(Double aDouble) {
System.out.println("学习太累了,去天上人间买了瓶矿泉水,价格为:" + aDouble);
}
});
System.out.println("********************");
happyTime(400,money -> System.out.println("学习太累了,去天上人间喝了口水,价格为:" + money));
}
public void happyTime(double money, Consumer<Double> con){
con.accept(money);
}
}
- Predicate接口
@Test
public void test2(){
List<String> list = Arrays.asList("北京","南京","天津","东京","西京","普京");
List<String> filterStrs = filterString(list, new Predicate<String>() {
@Override
public boolean test(String s) {
return s.contains("京");
}
});
System.out.println(filterStrs);
List<String> filterStrs1 = filterString(list,s -> s.contains("京"));
System.out.println(filterStrs1);
}
//根据给定的规则,过滤集合中的字符串。此规则由Predicate的方法决定
public List<String> filterString(List<String> list, Predicate<String> pre){
ArrayList<String> filterList = new ArrayList<>();
for(String s : list){
if(pre.test(s)){
filterList.add(s);
}
}
return filterList;
}
listFiles(Filefilter filter)文件过滤器的实现过程
jdk源码
过滤器 Filefilter
案例1 : 返回的类型是.txt文件
import java.io.File;
import java.io.FileFilter;
public class test01 {
public static void main(String[] args) {
File file = new File("E:\\011");
File[] files = file.listFiles(new FileFilter() {
@Override
public boolean accept(File pathname) {
return pathname.getName().endsWith(".txt");
}
});
for(File file1 :files){
System.out.println(file1.getName());
}
}
}
案例2 : 返回的类型包含world
- String 的matches()正则匹配
public class test02 {
public static void main(String[] args) {
File file = new File("E:\\011");
File[] files = file.listFiles(new FileFilter() {
@Override
public boolean accept(File pathname) {
return pathname.getName().matches(".*world+.*");
}
});
for(File file1 :files){
System.out.println(file1.getName());
}
}
}
- String 的contains()包含
public class test02 {
public static void main(String[] args) {
File file = new File("E:\\011");
File[] files = file.listFiles(new FileFilter() {
@Override
public boolean accept(File pathname) {
return pathname.getName().contains("world");
}
});
for(File file1 :files){
System.out.println(file1.getName());
}
}
}
lambda写法
@Test
public void test02(){
File file = new File("E:\\011\\src");
File[] files= file.listFiles(pathname->{
return pathname.getName().matches(".*world+.*");
}
);
for(File file1 :files){
System.out.println(file1.getName());
}
}
案例3 : 正则表达式匹配文件
集合 forEach(Consumer<? super E> action)
案例1:
@Test
public void test01() {
ArrayList<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
list.add("d");
list.add("e");
list.forEach(e -> System.out.println(e));
}
@Test
public void test01() {
ArrayList<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
list.add("d");
list.add("e");
list.forEach(System.out :: println);
}
案例 2:
@Test
public void test02() {
StringBuilder str = new StringBuilder();
ArrayList<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
list.add("d");
list.add("e");
list.forEach(e ->str.append(e).append("+"));
System.out.println(str);
}
案例 3:
@Test
public void test03() {
ArrayList<String> list = new ArrayList<>();
list.add("a");
list.add("b");
list.add("c");
list.add("d");
list.add("e");
list.forEach(item -> {
if (!"b".equals(item)) {
System.out.println(item);
}
});
}