Hi,大家好,我是编程小6,很荣幸遇见你,我把这些年在开发过程中遇到的问题或想法写出来,今天说一说stream流常用方法map_流的flush方法[通俗易懂],希望能够帮助你!!!。
比如我有个实体类User,User有个属性Name
public class User {
public User(String name, String age, int height) {
this.name = name;
this.age = age;
this.height = height;
}
private String name;
private String age;
private int height;
// setter、getter方法我就不写了
}
// 创建三个user
User user1 = new User("111", "18", 180);
User user2 = new User("222", "18", 175);
User user3 = new User("333", "19", 170);
现在我要创建3个user放到list中:
List<User> userList = new ArrayList<>();
userList.add(user1);
userList.add(user2);
userList.add(user3);
// stream流,创建的是动态数组,可以添加元素
List<User> userList = Stream.of(user1, user2, user3).collect(Collectors.toList());
本质是将一个数组转成list,数组的大小是固定的,所以此list不能添加元素,
如果调用add方法增加新的元素,会报异常:java.lang.UnsupportedOperationException
当元素是固定时,可以采用这个;
// 本质是将一个数组转成list,数组的大小是固定的,所以此list不能添加元素
// 如果调用add方法增加新的元素,会报异常:java.lang.UnsupportedOperationException
List<String> s = Arrays.asList("1","2","3")
拿上面userList举例,我取出list中所有user的name属性放到一个新的list中:
// 遍历
List<String> userNameList = new ArrayList<>();
for (User user : userList) {
userNameList.add(user.getName());
}
// Stream流
List<String> userNameList = userList.stream().map(User::getName).collect(Collectors.toList());
还拿上面的userList,比如我要筛选出userList中name不为空的user
List<User> newUserList = new ArrayList<>();
// if判断
for (User user : userList) {
if(user.getName() != null) {
newUserList.add(user);
}
}
// 获取userName不为空的user的List
List<User> userList = userList.stream().filter(user-> user.getName() != null).collect(Collectors.toList());
把userList中的user根据年龄分组:
Map<String, List<User>> map = new HashMap<>();
// if判断
for (User user : userList) {
if (map.get(user.getAge()) == null) {
map.put(user.getAge(), new ArrayList());
}
map.get(user.getAge()).add(user);
}
Map<String, List<User>> map =userList.stream().collect( Collectors.groupingBy(User::getAge, Collectors.toList()));
求和的普通遍历方式跟上面差不多,就不举例了;
// int、double、long:
double max = userList.stream().mapToDouble(User::getHeight).sum();
Map<String, User> userMap = new Map<>();
for (User user : userList) {
userMap.put(user.getName(), user);
}
用Collectors的toMap方法转换List,一般会遇到两个问题。
(1)转换map,key重复问题;
代码中使用(key1,key2)->key2表达式可以解决此类问题,如果出现重复的key就使用key2覆盖前面的key1,也可以定义成(key1,key2)->key1,保留key1,根据自己的业务场景来调整。
(2)空指针异常,即转为map的value是null。这个可以用filter过滤;
Map<String, User> userMap= userList.stream().collect(Collectors.toMap(User::getName, Function.identity(),(key1, key2)->key2));
(3)value是某一属性的值,例如,key是id,value是name:
Map<String, String> userMap = userList.stream().
collect(Collectors.toMap(User::getId, User::getName));
(3)若是map的key只想要对象的某个字段,则可以:
Map<String, String> userMap = userList.stream().
collect(Collectors.toMap(User::getName, User::getHeight));
List<User> userList = new List<>();
for (String userName : userMap.keySet()) {
userList.add(userMap.get(userName));
}
List<User> userList = userMap.entrySet().stream().map(e ->e.getValue()).collect(Collectors.toList());
判断的条件里,任意一个元素成功,返回true;
比如上面的userlList,我想判断是否有height > 175的:
userList.stream().anyMatch(user -> user.getHeight() > 175);
allMatch:判断条件里的元素,所有的都是,返回true;
比如上面的userlList,我想判断是否全部height > 175的:
userList.stream().allMatch(user -> user.getHeight() > 175);
与allMatch相反,判断条件里的元素,所有的都不是,返回true
userList.stream().noneMatch(user -> user.getHeight() > 175);
userList.stream().filter(user -> user.getHeight() > 175).count();
System.out.println(userList.stream().anyMatch(user -> user.getHeight() > 175));
System.out.println(userList.stream().allMatch(user -> user.getHeight() > 175));
System.out.println(userList.stream().noneMatch(user -> user.getHeight() > 175));
System.out.println(userList.stream().filter(user -> user.getHeight() > 175).count());
List<Integer> list1 = Arrays.asList(1, 2, 3);
List<Integer> list2 = Arrays.asList(4, 5, 6);
List<Integer> list3 = Arrays.asList(7, 8, 9);
List<Integer> mergedList = Stream.of(list1, list2, list3).flatMap(Collection::stream).collect(Collectors.toList());
System.out.println(mergedList);// [1, 2, 3, 4, 5, 6, 7, 8, 9]
结果:
List<String> list1 = Arrays.asList("张三", "李四", "王二麻子");
List<String> list2 = Arrays.asList("111", "222", "333");
// 合并前
List<List<String>> lists = Arrays.asList(list1, list2);
System.out.println(lists);
// 合并后
List<String> mergedList = lists.stream().flatMap(Collection::stream).collect(Collectors.toList());
System.out.println(mergedList);
结果:
Map<String,Object> map = Maps.newHashMap();
List list = new ArrayList();
//list -> 当前页所有数据
map.put("list",list.stream().skip((long) (pageNo - 1) * pageSize).limit(pageSize).collect(Collectors.toList()));
//count -> 记录总条数
map.put("count",list.size());
// 根据名称排序
list.stream().sorted(Comparator.comparing(User::getName)).collect(Collectors.toList());
以上均为个人使用记录,若有错误,欢迎指正!
今天的分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。
上一篇
已是最后文章
下一篇
已是最新文章