网站首页 > java教程 正文
Predicate接口(断言)Function接口(函数)Supplier接口(供应商)Consumer接口(消费者)Comparator接口(比较)Optional接口( 可选)
Optional
// 获取学生姓名
private String getInfoName1(Student student){
return student.getInfo().getName();
}
// 为了避免空指针异常,Java 8 之前修改为
private String getInfoName2(Student student){
if(student!=null){
Info info = student.getInfo();
if(info!=null){
String name = info.getName();
return name;
}
}
return null;
}
// Java 8 中使用Optional
private String getInfoName3(Student student){
return Optional.ofNullable(student).map(Student::getInfo).map(Info::getName)
.orElse("DEFAULT_NAME"); // DEFAULT_NAME 没有默认值,写成null即可
}
Supplier
Supplier 接口可以理解为一个容器,用于装数据的,也可以理解为用来创建对象的,
Supplier<String> supplier = new Supplier() {
@Override
public String get() {
return LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyyMMddHHmmssSSS"))
+ new Random().nextInt(10);
}
};
Student student = new Student();
String id = Optional.ofNullable(student).map(Student::getId)
.orElseGet(supplier); // 获取student的id,如果为null,则按时间戳随机生成一个ID
System.out.println(id);
Consumer(提取forEach)
在进行forEach的时候,forEach所需传入的参数就是一个Consumer,如果这个forEach的内部方法需要多处使用,提取成一个Consumer即可。
Consumer<Integer> consumer = (x) -> {
int number = x*2;
System.out.print(number);
};
Stream.of(1,2,3,4,5).forEach(consumer); // 打印246810
Stream.of(6,7,8,9,10).forEach(consumer); // 打印1214161820
Comparator
// 数字直接排序
List<Integer> list = Arrays.asList(1, 4, 2, 6, 2, 8);
list.sort(Comparator.naturalOrder()); // 升序
list.sort(Comparator.reverseOrder()); // 降序
// 对象按属性排序
Supplier<Student> supplier = () -> {
Student student = new Student();
student.setAge(new Random().nextInt(20));
student.setPrice(new Random().nextInt(100));
return student;
};
List<Student> students = Stream.generate(supplier).limit(10).collect(Collectors.toList());
students.sort(Comparator.comparingInt(Student::getAge).reversed()
.thenComparingInt(Student::getPrice)); // 先以年龄降序,再以价格升序
System.out.println(students);
Predicate(提取filter)
Predicate就是一个类似于 bool 类型的判断的接口
Predicate<Integer> predicate = (t) -> t > 10;
Stream<Integer> stream = Stream.of(1, 23, 3, 4, 5, 56, 6, 6);
List<Integer> list = stream.filter(predicate).collect(Collectors.toList());
list.forEach(System.out::println); // 输出10以上的数字
Function(提取map)
function作用就是转换作用,将输入数据转换成另一种形式的输出数据
Function<String, Integer> function = new Function<String, Integer>() {
@Override
public Integer apply(String s) {
return s.length();//获取每个字符串的长度,并且返回
}
};
Stream<String> stream = Stream.of("aaa", "bbbbb", "ccccccv");
Stream<Integer> stream1 = stream.map(function);
stream1.forEach(System.out::println); // 输出字符串的长度
- 上一篇: java小知识-纳秒 纳秒是什么
- 下一篇: 「Java」 桌面字幕——实时语音翻译
猜你喜欢
- 2024-12-24 java小知识-纳秒 纳秒是什么
- 2024-12-24 弃用 Java 8,Apache Kafka 3.0 发布
- 2024-12-24 Sharding Sphere-JDBC从入门到实战,一顿饭的时间让你学懂
- 2024-12-24 Java虚拟机之 XX:+UseGCLogFileRotation 解析
- 2024-12-24 阿里Java三面:分布式延时任务方案解析,万字长文一篇点通你
- 2024-12-24 拯救Java应用:Arthas监控术,让你事半功倍
- 2024-12-24 java+uniapp实现微信JSSDK扫码功能
- 2024-12-24 filebeat收集K8S日志,写入自动创建的索引
- 2024-12-24 Java 动态调试技术原理及实践 java动态配置
- 2024-12-24 美团高并发分布式架构下的唯一ID生成方式,看这篇就够了
你 发表评论:
欢迎- 04-27微服务部署架构设计详解(图文全面总结)
- 04-27Java微服务架构选型与对比:一场技术流派的巅峰对决
- 04-27微服务架构下Java的最佳实践
- 04-27Java微服务架构选型:优雅拆分与高效整合
- 04-27微服务架构下的Java代码拆分策略:像拼图一样构建系统
- 04-27微服务架构下的Java最佳实践
- 04-27微服务架构下Java的挑战与机遇
- 04-27微服务架构下Java事务管理的艺术
- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)