java8 lambda 获取list对象中重复数据

工作上的场景,简单记录一下:

在这里直接借用业务上的list,不再new 了。

List<AlarmStatisticsListOutput> alarmList = spareAlarmStatisticsMapper.selectAlarmStatistics(unitIdList);

根据对象中的某个字段分组,得到重复数据,在这里用了对象中的一个字段spareId

Map<String, List<AlarmStatisticsListOutput>> groupMap = alarmList.stream().collect(Collectors.groupingBy(AlarmStatisticsListOutput::getSpareId));

在这里可以循环map,获取value中的list的size()>1的数据。

for (Map.Entry<String, List<AlarmSpareOutput>> map : groupMap.entrySet()) {
	  if (map.getValue().size() > 1) {
	     //处理业务
	  }
	}

获取重复数据的个数

List<String> count = groupMap.keySet().stream().filter(key -> groupMap.get(key).size() > 1).distinct().collect(Collectors.toList());
  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
### 回答1: 可以使用Java 8的流(Stream)和Lambda表达式来获取List重复数据。下面是一些示例代码: 1. 找到所有重复元素: ```java List<String> list = Arrays.asList("A", "B", "C", "A", "D", "B"); List<String> duplicates = list.stream() .collect(Collectors.groupingBy(Function.identity(), Collectors.counting())) .entrySet().stream() .filter(e -> e.getValue() > 1) .map(Map.Entry::getKey) .collect(Collectors.toList()); System.out.println(duplicates); // 输出 [A, B] ``` 这段代码首先使用`groupingBy`方法将元素分组,然后使用`filter`方法过滤出出现次数大于1的元素,并使用`map`方法将`Map.Entry`转换为其键值,最后将结果收集到一个List。 2. 找到第一个重复元素: ```java List<String> list = Arrays.asList("A", "B", "C", "A", "D", "B"); Optional<String> firstDuplicate = list.stream() .filter(new HashSet<>()::add, HashSet::new) .findFirst(); System.out.println(firstDuplicate.orElse(null)); // 输出 A ``` 这段代码首先创建了一个空的HashSet,然后使用`filter`方法过滤出第一个无法添加到HashSet元素,即为第一个重复元素。最后使用`findFirst`方法获取结果。注意,由于结果可能为null,因此使用`Optional`类包装结果。 希望这可以帮助到你! ### 回答2: 在Java 8,我们可以使用 Stream API 来获取 List 重复数据。 首先,我们将 List 转换为 Stream 对象,然后使用 `Collectors.groupingBy` 方法对元素进行分组,相同的元素将会分到同一组。 接着,我们使用 Stream 对分组结果进行过滤,筛选出有多个元素的组,即为重复数据。 最后,我们将过滤出的组的键值提取出来,即为 List 重复数据。 下面是一个示例代码: ```java import java.util.Arrays; import java.util.List; import java.util.Map; import java.util.stream.Collectors; public class Main { public static void main(String[] args) { List<Integer> list = Arrays.asList(1, 2, 3, 2, 4, 5, 4, 6); List<Integer> duplicates = list.stream() .collect(Collectors.groupingBy(e -> e, Collectors.counting())) .entrySet() .stream() .filter(entry -> entry.getValue() > 1) .map(Map.Entry::getKey) .collect(Collectors.toList()); System.out.println("List 重复数据:" + duplicates); } } ``` 运行代码后输出结果为:List 重复数据:[2, 4] ,即 List 重复元素是 2 和 4。 ### 回答3: 要获取一个Java 8List重复数据,可以按照以下步骤进行操作: 1. 创建一个HashMap对象,该对象的键是List元素,值是元素出现的次数。 2. 使用Java 8的stream()方法将List转换为Stream。 3. 使用forEach()方法对Stream元素进行迭代。 4. 在迭代,使用HashMap的merge()方法将元素作为键,并将其值初始化为1,如果已存在相同的键,则将其值加1。 5. 创建一个新的ArrayList对象,用于存储重复元素。 6. 再次使用stream()方法将List转换为Stream。 7. 使用filter()方法对Stream元素进行过滤,根据HashMap键对应的值是否大于1来判断是否为重复元素。 8. 使用collect()方法将Stream的过滤出的元素收集到ArrayList。 9. 最后,你可以打印或做其他操作,来验证获取重复元素是否正确。 以下是一个示例代码: ``` import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; public class Main { public static void main(String[] args) { List<Integer> list = new ArrayList<>(); list.add(1); list.add(2); list.add(3); list.add(2); list.add(4); list.add(1); Map<Integer, Integer> countMap = new HashMap<>(); list.stream().forEach(num -> countMap.merge(num, 1, Integer::sum)); List<Integer> duplicates = list.stream() .filter(num -> countMap.get(num) > 1) .collect(Collectors.toList()); System.out.println("重复元素:" + duplicates); } } ``` 这个示例代码将会输出:重复元素:[1, 2]。它会将List重复元素找到,并存储在新的ArrayList对象

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值