lambda表达式(4)(Shawn)

});

if (rs) {
System.out.println(“list1中包含PHP 字符”);
} else {
System.out.println(“list1中不包含PHP 字符”);
}
}

main方法中,调用checkChar()方法的时候,传入lambda表达式s->{return s.contains("PHP")}来进行判断。这意思就是说在调用checkChar方法的时候如果list1列表中包含PHP这个元素执行System.out.println("满足对应的条件")语句。

上述代码执行结果为:

满足对应的条件
list1中包含PHP 字符

2.2 与判断

上面我们说了单个条件判断,如果想多个条件判断怎么办?可以使用Predicate的and()方法。

我们先定义一个函数,这个函数里会进行两个判断,两个判断具体的逻辑由外部传过来。

private static boolean checkChar2(List list1, Predicate pre, Predicate other) {
return pre.and(other).test(list1);
}

main方法中,传入两个判断逻辑 s -> { return s.contains("PHP");} s -> { return s.contains("C++");},然后通过Predicate.and()方法执行与操作。

public static void main(String[] args) {
List list1 = new ArrayList();
list1.add(“PHP”);
list1.add(“JAVA”);
list1.add(“C++”);
boolean rs = checkChar2(list1, s -> {
return s.contains(“PHP”);
}, s -> {
return s.contains(“C++”);
});

if (rs) {
System.out.println(“list1同时有PHP和C++字符”);
} else {
System.out.println(“list1不满足同时有PHP和C++字符”);
}
}

上述代码的执行结果为:

list1同时有PHP和C++字符

2.3 非判断

“与”、“或"我们已经了解了,剩下还有一个"非”(取反)操作,我们看一下取反操作negate如何使用。

Predicatenegate()方法如下:

default Predicate negate() {
return (t) -> !test(t);
}

从源码我们可以看到negate方法是在执行了test()方法之后,对结果boolean值进行取反而已。请注意,一定要先调用negate方法然后调用test方法 ,这个跟andor方法一样:

private static boolean checkNotChar(List list1, Predicate pre1) {
return pre1.negate().test(list1);
}

public static void main(String[] args) {
List list1 = new ArrayList();
list1.add(“PHP”);
list1.add(“JAVA”);
list1.add(“C++”);
boolean rs = checkNotChar(list1, s -> {
return s.contains(“C#”);
});

if (rs) {
System.out.println(“list1没有C#”);
} else {
System.out.println(“list1有C#”);
}
}

上述代码执行结果为:

list1没有C#

3. Function接口

java.util.function.Function<T,R>相当于数据中的函数,一个类型的数据作为输入得到另一个类型数据的输出。

3.1 转换方法:apply

Function中执行转换的方法为抽象方法R apply(T t),该方法根据参数T类型数据获取类型为R的结果。比如下面我要将String类型转化为Integer类型。具体如何转换由调用方通过lambda来决定。

我们先定义转换的方法:

private static Integer transfer(String param, Function<String, Integer> function) {
int num = function.apply(param);
return num;
}

具体转换逻辑在main方法中定义:

public static void main(String[] args) {
String str = “99”;
int num = transfer(str, s -> (Integer.parseInt(s) + 1));//这里定义具体的转换逻辑
System.out.println(“DemoFunc执行结果为” + num);
}

3.2 级联转换:andThen

如果我们想做多步转换那么就需要用到andThen()方法了,这些具体转换的实现在调用放通过lambda来实现。

我先定义一个级联转换的方法chainTransfer,该方法中传入三个Function依次经过one,two,three进行转换,然后返回结果。

private static Integer chainTransfer(String str, Function<String, Integer> one, Function<Integer, Integer> two,
Function<Integer, Integer> three) {
int num = one.andThen(two).andThen(three).apply(str);
return num;
}

下面在main方法中实现3个Function然后调用转换函数chainTransfer

public static void main(String[] args) {
int num = chainTransfer(“9”, str -> Integer.parseInt(str) + 10,
i -> i *= 10, i -> i + 5);
System.out.println(“转换后的结果为:” + num);
}

我们执行上面main方法结果为:

转换后的结果为:195

具体转换步骤为:

  1. 先将9转换成Integer类型然后+10,对应Integer.parseInt(str) + 10,得到19;
  2. 然后乘以10,得到19*10 = 190;
  3. 第三部加5,得到190+5 = 195。

当然定义这个方法的时候有一个要注意的,依赖被调用的Function参数类型要是适配,比方说Function<String,Integer> one入参为String返回值为Integer,那么后面Function two 的入参必须是Integer。即前一个Function的返回值跟后一个Function入参类型应该兼容。

3.2 讨论级联转换中的类型兼容问题

前面我们说了,即前一个Function的返回值跟后一个Function入参类型应该兼容。因为前一个Function是后一个Function的入参,在函数调用中当实际入参是形参的子类那么是兼容的。

即如下的转换函数式兼容的:

private static User objChainTransfer(String str, Function<String, VipUser> one, Function<User, User> two) {
User u = one.andThen(two).apply(str);
return u;
}
}

前面一个Function返回的是VipUser,其为第二个Function的入参User的子类。我们在main函数中调用上面的函数,其代码如下:

public static void main(String[] args) {
User u = objChainTransfer(“19”, str -> {
return new VipUser(“name” + str, str);

最后

考虑到文章的篇幅问题,我把这些问题和答案以及我多年面试所遇到的问题和一些面试资料做成了PDF文档

喜欢的朋友可以关注、转发、点赞 感谢!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!
外链图片转存中…(img-FLg0Dhgi-1714769057536)]

[外链图片转存中…(img-b57ME6aD-1714769057539)]

喜欢的朋友可以关注、转发、点赞 感谢!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

  • 20
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值