1. 背景
以前项目一直使用的是JDK6,现在接触的项目都是使用JDK8,里面有大量的新特性,例如lambda表达式,函数式接口等等,感觉和时代脱节了,所以,必须要好好地总结一下。
2. Predicate使用
2.1 使用test
/**
* 返回名字长度>5的成员
*
*/
@Test
public void predicateTest() {
List<String> list = Arrays.asList("Tom", "Jack", "Hello", "xy wei", "A", "B");
Predicate<String> predicate = str -> str.length() > 4;
list.stream().filter(predicate).forEach(System.out::println);
}
输出结果:
2.2 使用and
相当于我们if
中使用的&&
/**
* 返回名字长度>5的成员,并且以xy开头的
*
*/
@Test
public void predicateAnd() {
List<String> list = Arrays.asList("Tom", "Jack", "Hello", "xy wei", "A", "B", "");
Predicate<String> predicate1 = str -> str.length() > 4;
Predicate<String> predicate2 = str -> str.startsWith("xy");
list.stream().filter(predicate1.and(predicate2)).forEach(System.out::println);
System.out.println("---使用万能test--");
Predicate<String> predicate3 = s -> s.length() > 5 && s.startsWith("xy");
list.stream().filter(predicate3).forEach(System.out::println);
}
and也可以使用test替换,输出如下:
2.3 使用or
就是逻辑运算的||
/**
* 返回名字长度<5的成员,或者以xy开头的
*
*/
@Test
public void predicateOr() {
List<String> list = Arrays.asList("Tom", "Jack", "Hello", "xy wei", "A", "B", "");
Predicate<String> predicate1 = str -> str.length() < 5;
Predicate<String> predicate2 = str -> str.startsWith("xy");
list.stream().filter(predicate1.or(predicate2)).forEach(System.out::println);
System.out.println("---使用万能test--");
Predicate<String> predicate3 = s -> s.length() < 5 || s.startsWith("xy");
list.stream().filter(predicate3).forEach(System.out::println);
}
同样,也可以直接使用test替换,输出如下:
2.4 使用negate
就是我们的逻辑非!
/**
* 返回名字长度!=5的名字
*
*/
@Test
public void predicateNegate() {
List<String> list = Arrays.asList("Tom", "Jack", "Hello", "xy wei", "A", "B", "");
Predicate<String> predicate1 = str -> str.length() == 5;
list.stream().filter(predicate1.negate()).forEach(System.out::println);
System.out.println("---使用万能test--");
Predicate<String> predicate3 = s -> s.length() != 5;
list.stream().filter(predicate3).forEach(System.out::println);
}
输出:
3. 总结
- 项目组要求有代码量,那么,使用predicate是个好选择,哈哈。
- 在平时开发中,应该何时选择predicate?个人决定可以在使用lambda表达式中,如果特别复杂,可以使用predicate来清晰代码。