当前位置:网站首页>关于Stream和Map的巧用
关于Stream和Map的巧用
2022-07-06 09:30:00 【机智的爆爆哥】
题目是这样的
//假设db中有两个这样的表 数据有100w 最终要返回的是Provice表的List集合 如果status为fasle 则不返回 如何在java层面解决呢?
public class Mydemo {
static ArrayList<Province> provinces = new ArrayList<>();
static ArrayList<ProvinceStatus> provinceStatusList = new ArrayList<>();
static {
for (int i = 0; i < 10000; i++) {
Province province = new Province();
ProvinceStatus provinceStatus = new ProvinceStatus();
province.setName(UUID.randomUUID().toString());
province.setProvinceId(i);
provinceStatus.setProvinceId(i);
provinceStatus.setStatus(new Random().nextBoolean());
//添加
provinces.add(province);
provinceStatusList.add(provinceStatus);
}
System.out.println("显示的列表大小为:" + provinceStatusList.stream().filter(ProvinceStatus::getStatus).count());
}
public static void main(String[] args) {
ArrayList<Province> resList = new ArrayList<>();
System.out.println("最终显示的个数:" + resList.size());
}
}
@Data
class Province {
private Integer provinceId;
private String name;
}
@Data
class ProvinceStatus {
private Integer provinceId;
private Boolean status;
}
答案如下,有更好的想法请留言哦!
public static void main(String[] args) {
//双重for循环? 不 用hash是个好办法
long start1 = System.currentTimeMillis();
System.out.println();
Map<Integer, Boolean> map = provinceStatusList.stream()
.collect(Collectors.toMap(ProvinceStatus::getProvinceId, ProvinceStatus::getStatus));
ArrayList<Province> resList = new ArrayList<>();
for (Province province : Mydemo.provinces) {
if (map.get(province.getProvinceId())) {
//显示这些
resList.add(province);
}
}
long start2 = System.currentTimeMillis();
System.out.println("用时:" + (start2 - start1));
System.out.println("最终显示的个数:" + resList.size());
}
}
实测在数据量大的时候,并行流反而速度更慢,应该是因为没有经过什么计算,毕竟并行流适合CPU密集型的任务,即包含大量计算的时候使用。
边栏推荐
猜你喜欢
随机推荐
汇编课后作业
Shell_ 04_ Shell script
DS18B20数字温度计系统设计
Resume of a microservice architecture teacher with 10 years of work experience
MySQL字符串函数
Introduction to microservices
面试集锦库
原型链继承
~72 horizontal and vertical alignment of text
~76 sprite map
Shell_ 03_ environment variable
Shell_ 07_ Functions and regular expressions
Alibaba cloud server builds SVN version Library
Shell_ 02_ Text three swordsman
冯诺依曼体系结构
搭建flutter环境入坑集合
Eureka high availability
ByteDance open source Gan model compression framework, saving up to 97.8% of computing power - iccv 2021
7-12 inventory code base
我走过最迷的路,是字节跳动程序员的脑回路