1.list转map(List<User> 转 Map<user.getUid,user>)
Map<Integer, User> userMap = userList.stream().collect(Collectors.toMap(User::getUid,Function.identity()));
2.list转map并且分组(根据list中的对象的一个属性分组,类似于sql的groupby)
Map<Integer, List<User>> usermap = userList.stream().collect(Collectors.groupingBy(User::getUid));
3.对集合中的每一个元素进行修改(如果元素为对象,也可以修改对象的属性)
下面代码中lambda表达式中x代表着userList中的元素对象也就是User对象(参数) -> 右边的表示方法体
userList.forEach(x -> x.setUsername("迭代遍历"+user.getUsername()));
4.map转list
5.筛选list
filter函数的()里,应该放逻辑,判断条件,将符合条件的放到resultList中
List<User> resultList = userList.stream().filter(user -> user.getUid() == 2).collect(Collectors.toList());
6.list去重复(根据User对象的uid属性去重)
List<User> oneList = getUserList(3);
List<User> twoList = getUserList(3);
oneList.addAll(twoList);
System.out.println("去重前:"+oneList);
List<User> distinctList = oneList.stream().filter(distinctByKey(o -> o.getUid())).collect(Collectors.toList());
System.out.println("去重后:"+distinctList);
public static <T> Predicate<T> distinctByKey(Function<? super T,Object> keyExtractor){
Map<Object,Boolean> been = new ConcurrentHashMap<>();
//putIfAbsent()方法是如果key不存在则put如map中,并返回null
//若key存在,则直接返回key所对应的value值
return t -> been.putIfAbsent(keyExtractor.apply(t),Boolean.TRUE) == null;
}
7.集合和数组之间得转换
1:List<String> strList = Arrays.asList("AA", "BB", "CC");
2:集合转换为逗号拼接得形式:String newStr = strList.stream().collect(Collectors.joining(","));
3:将逗号分隔的字符串转换为List
String str = "a,b,c";
List<String> result = Arrays.asList(str.split(","));
4:将List转换为逗号分隔的字符串
1) 利用Guava的Joiner
List<String> list = new ArrayList<String>();
list.add("a");
list.add("b");
list.add("c");
String str = Joiner.on(",").join(list);
(2)利用Apache Commons的StringUtils
List<String> list = new ArrayList<String>();
list.add("a");
list.add("b");
list.add("c");
String str = StringUtils.join(list.toArray(), ",");