java List<对象> 根据对象的一个属性进行去重

1.如果你想根据对象的一个属性进行去重,可以使用Java 8中的Stream API。具体步骤如下:

1.实现一个自定义函数,该函数将用于确定两个对象是否相等,例如:

public static  Predicate distinctByProperty(Function keyExtractor) {
    Map map = new ConcurrentHashMap<>();
    return t -> map.putIfAbsent(keyExtractor.apply(t), Boolean.TRUE) == null;
}

这个函数接受一个Function对象作为参数,该函数将从对象中提取唯一标识属性,并使用ConcurrentHashMap来确定是否已经处理过该属性值。 

 2.现在你可以使用这个函数来进行去重了,例如:

List myList = ... // Your list of objects
List distinctList = myList.stream().filter(distinctByProperty(MyObject::getSomeProperty)).collect(Collectors.toList());

 这个代码将对myList进行去重,只保留唯一的对象(即,他们的某个属性相同)。其中,getSomeProperty是MyObject类中的一个方法,它返回用于去重的属性

2.一行代码完成

ArrayListlist1=list.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(()->newTreeSet<>(Comparator.comparing(BasicSectionCfg::getPamKey))),ArrayList::new));

这段代码使用Java 8中的流API将一个ArrayList进行去重并转换成另一个ArrayList。

具体来说,大致可以分为以下几步:

  1. 使用stream()方法将原始的ArrayList转换成一个流Stream
  2. 使用collect()方法将流Stream收集并转换成另一个集合。collect()方法接收一个Collector对象,并且Collectors类中提供了许多预定义的Collector实现,方便我们使用。在本段代码中,我们使用了Collectors.collectingAndThen()方法,它将一个Collector转换成另一个Collector,并在最后的结果上进行一些操作。
  3. 在Collectors.collectingAndThen()方法中,我们传递了两个参数:
    1. 第一个参数是Collectors.toCollection()方法,它创建了一个新的TreeSet集合,该集合使用Comparator.comparing()方法来对元素进行排序。其中Comparator.comparing()方法接收一个Function参数,该函数用于提取对象的某个属性,这里我们使用BasicSectionCfg::getPamKey方法来提取BasicSectionCfg对象的pamKey属性。
    2. 第二个参数是一个lambda表达式,它将TreeSet转换成ArrayList集合。具体地,它调用了ArrayList的构造函数,并将TreeSet作为参数传递给构造函数。

最终,这段代码的作用就是将list中的重复元素去重,并按照BasicSectionCfg对象的pamKey属性进行排序,得到一个新的ArrayList集合。

你可能感兴趣的:(JAVA,SE,进阶,java,list)