lambda表达式(4)(Shawn),kotlin开源项目

本文介绍了Kotlin中Lambda表达式的使用,包括Function接口的应用,如apply、andThen方法,并讨论了级联转换中的类型兼容问题。通过示例展示了如何在实际代码中实现逻辑判断和数据转换。
摘要由CSDN通过智能技术生成

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);
}, vipUser -> {
vipUser.setName(vipUser.getName() + “_new”);
return vipUser;
});
{
User u = objChainTransfer(“19”, str -> {
return new VipUser(“name” + str, str);
}, vipUser -> {
vipUser.setName(vipUser.getName() + “_new”);
return vipUser;
});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值