jdk1.8对 List<Map<String, Object>>写法

用stream流处理集合是一件快乐的事情,加上Lambda表达式的加持,代码优雅简洁。下面我给出我处理List<Map<String, Object>> 集合的写法用函数式编程去写

1.对集合进行分组,求和,平均值,最大最小值计算

  List<Map<String, Object>> listMap = new ArrayList<>();
  LinkedHashMap<String, Object> map = new LinkedHashMap<>();
   map.put("sceneId", "1");
  map.put("name", "阿龙");
  map.put("age","18");
  map.put("birthday","2002-01-01");
  .........
  listMap.add(map);
  ## 对listMap 进行分组操作(根据id分组)
Map<String, List<Map<String, Object>>> groupByEmpId = listMap.stream().collect(groupingBy(e -> e.get("sceneId").toString()));
 groupByEmpId.forEach((k, sList) -> {
      BigDecimal singleAmount = lists.stream().map(x -> new 
## 统计和  (根据年龄)    BigDecimal(x.get("age").toString())).reduce(BigDecimal.ZERO, BigDecimal::add);

##我们用得到的结果 singleAmount.get  会发现,可以直接获取平均值,最大最小值
  });  

2.排序

##对list按照某个条件排序(可以按照时间,也可以按照id,名字等等)
List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
Map<String, Object> map1 = new HashMap<String, Object>();
//名字
map1.put("name", "阿龙");
 //年龄
map1.put("age", 18);   
//出生年月日
map1.put("birth", "2002-01-01 11:11:11");
list.add(map1);
Map<String, Object> map3 = new HashMap<String, Object>();
map3.put("name", "1");
map3.put("age", 38);
map3.put("birth", "2002-02-01 11:11:11");
list.add(map3);
Map<String, Object> map5 = new HashMap<String, Object>();
map5.put("name", "2");
map5.put("age", 20);
map5.put("birth", "2002-01-02 11:11:11");
list.add(map5);
Map<String, Object> map6 = new HashMap<String, Object>();
map6.put("name", "3");
map6.put("age", 22);
map6.put("birth", "2002-01-03 11:11:11");
list.add(map6);
//匿名实现Comparator接口进行排序
Collections.sort(list, new Comparator<Map<String,Object>>() {
SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
public int compare(Map<String, Object> o1, Map<String, Object> o2) {
int result = 0;
//进行判断
try {
//升序
result = (formatter.parse((String)o1.get("birth"))).compareTo(formatter.parse((String)o2.get("birth")));
//降序
//result = (formatter.parse((String)o2.get("birth"))).compareTo(formatter.parse((String)o1.get("birth")));
} catch (ParseException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return result;
}
});

3.条件筛选

List<Map<String, Object>> listMap = new ArrayList<>();
  LinkedHashMap<String, Object> map = new LinkedHashMap<>();
   map.put("sceneId", "1");
   map.put("name", "阿龙");
   map.put("age","18");
   map.put("birthday","2002-01-01");
   listMap.add(map);
   ##按照某条件筛选数据
   private List<Map<String, Object>> getList(List<Map<String, Object>> listMap , String ids) {
        List<Map<String, Object>> arrayList = new ArrayList<>();
        List<Map<String, Object>> mapList = null;
        // 根据设备id进行过滤数据
        List<String> idList = null;
        if (ids != null && !StringUtils.isEmpty(ids)) {
            idList = lists(ids);
            for (String id : idList) {
                mapList =
                        list.stream().filter(e -> id.equals(e.get("sceneId"))).collect(Collectors.toList());
                arrayList.addAll(mapList);
            }
        }
        return arrayList;
    }

4.对集合进行去重操作

List<Map<String, Object>> listMap = new ArrayList<>();
  LinkedHashMap<String, Object> map = new LinkedHashMap<>();
   map.put("sceneId", "1");
   map.put("name", "阿龙");
   map.put("age","18");
   map.put("birthday","2002-01-01");
   listMap.add(map);
## 去重操作
dataList = listMap .stream().collect(Collectors.collectingAndThen(
				Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(p -> p.get("name")))),
				ArrayList::new));

5.流式字符串转list

    String ids = StringUtils.join(menuIds.toArray(), ",");
                if (!ids.isEmpty()) {
                    List<Long> listIds = Arrays.asList(ids.split(",")).stream().map(s -> Long.parseLong(s.trim()))
                            .collect(Collectors.toList());
  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
### 回答1: Java 8是一个非常重要的版本,它提供了许多新的特性和功能。这里是一些Java 8的新特性的案例: 1. Lambda表达式:Lambda表达式是一种新的匿名函数,允许您直接在代码中传递函数。例如,可以使用lambda表达式来创建并运行线程: ``` Thread t = new Thread(() -> System.out.println("Hello from a thread!")); t.start(); ``` 2. Stream API:Stream API是Java 8中的一个新功能,允许您使用函数式编程风格处理数据集合。例如,可以使用Stream API计算列表中所有数字的平均值: ``` List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5); double average = numbers.stream().mapToInt(i -> i).average().getAsDouble(); System.out.println("Average: " + average); ``` 3. 接口的默认方法:在Java 8中,接口可以有默认方法,即在接口中定义的带有实现的方法。这允许在不修改已实现该接口的类的情况下向接口添加新方法。例如,可以定义一个接口来表示形状,并在接口中定义一个默认方法来计算形状的面积: ``` public interface Shape { double getArea(); default double getPerimeter() { return 0; } } public class Circle implements Shape { private double radius; public Circle(double radius) { this.radius = radius; } @Override public double getArea() { return Math.PI * radius * radius; } } ``` 这些只是Java 8的一些新特性的例子。 ### 回答2: Java 8是Java编程语言的一个重要版本,引入了许多新特性和改进,以下是一些Java 8的新特性案例。 1. Lambda表达式:Java 8引入了Lambda表达式,可以更简洁地编写函数式接口的实现。例如,使用Lambda表达式实现Comparator接口进行字符串排序可以写作:List<String> list = Arrays.asList("c", "a", "b"); list.sort((s1, s2) -> s1.compareTo(s2)); 2. Stream API:Stream API提供了一种新的抽象数据类型,用于操作集合和数组。通过使用Stream API,可以非常方便地进行集合的过滤、转换和操作。例如,计算集合中所有偶数的平方和可以写作:List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5); int sum = numbers.stream().filter(n -> n % 2 == 0).mapToInt(n -> n * n).sum(); 3. Optional类:Optional类是一种用于处理可能不存在的值的容器类。它可以避免空指针异常,提供更好的代码可读性。例如,使用Optional类可以更安全地获取一个可能为空的字符串长度:Optional<String> optional = Optional.ofNullable(str); int length = optional.map(String::length).orElse(0); 4. 新的日期/时间API(Date and Time API):Java 8引入了全新的日期/时间API,提供了更强大和易用的日期和时间处理功能。新的日期/时间API提供了LocalDate、LocalTime、LocalDateTime等类,用于处理日期、时间和日期时间。例如,获取当前日期时间可以写作:LocalDateTime now = LocalDateTime.now(); 5. 并发增强:Java 8引入了新的并发工具,如CompletableFuture、Stream和ParallelStream等,用于方便地实现并发编程。例如,使用ParallelStream执行并行计算可以提高性能:IntStream.range(1, 10).parallel().forEach(System.out::println); 这些是Java 8的一些新特性案例,这些新特性使得Java编程更加简洁、高效和易用,提供了更多的编程选择和便利。 ### 回答3: Java 8是Java编程语言的一个重大更新版本,引入了许多令人兴奋的新特性。下面我将举几个例子来说明Java 8的一些新特性。 首先,Java 8引入了Lambda表达式。Lambda表达式使得我们能够以一种更简洁和声明式的方式编写代码。例如,在过去,我们经常需要使用匿名内部类来实现某个接口的方法,现在我们可以使用Lambda表达式来代替这种冗长的写法。比如,我们可以通过以下方式来实现一个Runnable接口的run方法: ``` Runnable runnable = () -> { System.out.println("Hello, World!"); }; ``` 第二个例子是函数式接口。函数式接口是一个只包含一个抽象方法的接口,它可以被Lambda表达式所实现。Java 8提供了许多内置的函数式接口,如Consumer、Function和Predicate。这些函数式接口使得我们能够以更直观的方式处理集合和流操作。例如,我们可以使用Predicate接口来筛选一个集合中的元素: ``` List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10); List<Integer> evenNumbers = numbers.stream() .filter(n -> n % 2 == 0) .collect(Collectors.toList()); ``` 第三个例子是Stream API。Stream API提供了一种新的方式来处理集合数据,它引入了一些类似于SQL查询的操作,如map、filter、reduce和collect等。Stream API使得我们能够以一种更优雅和简单的方式进行复杂的集合操作。例如,我们可以使用Stream API来计算一个集合中所有元素的和: ``` List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10); int sum = numbers.stream() .reduce(0, Integer::sum); ``` 总之,Java 8引入了许多令人兴奋的新特性,如Lambda表达式、函数式接口和Stream API。这些新特性使得我们能够以一种更简洁、高效和优雅的方式编写Java代码,提高代码的可读性和可维护性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

郭优秀的笔记

你的支持就是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值