为什么使用函数式接口只有一个必须被重写的抽象方法的接口
@FunctionalInterface 注解强制检测是否为函数式接口
代码举例:当重写函数式接口的方法后,发现,这个方法中执行逻辑相同,只有判断规则不同,就把判断规则抽取出来,自己定义,提高代码复用性
//在类的尖括号中 表示需要的泛型个数 ,T和R两种泛型 @FunctionalInterface interface Class003_TestLambda用Lambda表达式使用函数式接口{ //返回值类型是提供的 R 泛型,提供的两个参数类型一致为 T类型 public R getR(T t,T r); }
lambda表达式的使用
class TestLambda001{
public static void main(String[] args) {
//2:调用定义的方法,传递参数,第三个直接传递lambda表达式,使用表达式中规则
System.out.println(getAdd(1L, 2L, (a,b)-> a< testLambda001){
return testLambda001.getR(l1,l2);
}
}
每一步解析如何调用执行
jdk中的四大内置函数式接口 内置函数式接口作用
内置函数式接口代码使用Demo当你需要写一个方法,方法中有一段代码规则或者逻辑不固定,为了提高方法的复用【灵活性】,将判断规则或者逻辑放在外面,交由执行的时候具体在定义,
这时候需要一个函数式接口,可以直接使用内置的符合需要的函数式接口
public class Class001_FunctionalInterface {
public static void main(String[] args) {
testComsumer(5000,m-> System.out.println("为主播打赏消费"+m));
testComsumer(10000,m-> System.out.println("今天做全身spa消费"+m));
System.out.println(strHandler(" 哈哈 ",s->s.trim()));
System.out.println(strHandler(" abc ",s->s.toUpperCase()));
//[5,10]
System.out.println(testNumRandom(5,()->(int)(Math.random()*(10-5+1)+5)));
System.out.println(testNumRandom(10,()->(int)(Math.random()*(20-10+1)+10)));
System.out.println(testString(List.of("张三","李四","张三丰","欧阳王渊"),s->s.length()>=3));
}
//对一个集合中的多个字符串进行某种规则的过滤,返回过滤后的结果
public static List testString(List list, Predicate pre){
//定义一个List集合,存储满足条件的字符串
List strs = new ArrayList<>();
//遍历原list集合,拿到每一个字符串进行判定
for(String s :list){
//满足条件字符串放入strs集合
if(pre.test(s)){
strs.add(s);
}
}
return strs;
}
//功能: 提供指定个数的,指定规则的随机整数
//定义方法: 1)需求 2)参数: 不确定的数据|有可能会改变的数据定义参数列表上 3)返回值: 方法执行完毕是否需要得到一个结果,需要定义返回值 4)方法名 : 见名知意
public static List testNumRandom(int num, Supplier sup){
//定义一个List集合,存储生成的随机数
List list = new ArrayList<>();
//循环num次,每次调用get方法生成一个随机数
for(int i=1;i<=num;i++){
list.add(sup.get());
}
//返回结果
return list;
}
//功能: 对一个字符串进行某种行为的操作得到结果
public static String strHandler(String str, Function fun){
return fun.apply(str);
}
//功能: 每天的缴费记录
public static void testComsumer(double money, Consumer con){
con.accept(money);
}
}



