欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java中List<對(duì)象>如何根據(jù)對(duì)象的一個(gè)屬性進(jìn)行去重

 更新時(shí)間:2023年08月23日 11:07:22   作者:一只小念  
這篇文章主要給大家介紹了關(guān)于java中List<對(duì)象>如何根據(jù)對(duì)象的一個(gè)屬性進(jìn)行去重的相關(guān)資料,在開發(fā)中可能會(huì)遇到很多需要去重的情況,比如Person對(duì)象有name跟age兩個(gè)屬性,需要根據(jù)age進(jìn)行去重,需要的朋友可以參考下

1.如果你想根據(jù)對(duì)象的一個(gè)屬性進(jìn)行去重,可以使用Java 8中的Stream API。

具體步驟如下:

1.實(shí)現(xiàn)一個(gè)自定義函數(shù),該函數(shù)將用于確定兩個(gè)對(duì)象是否相等,例如:

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

這個(gè)函數(shù)接受一個(gè)Function對(duì)象作為參數(shù),該函數(shù)將從對(duì)象中提取唯一標(biāo)識(shí)屬性,并使用ConcurrentHashMap來確定是否已經(jīng)處理過該屬性值。 

2.現(xiàn)在你可以使用這個(gè)函數(shù)來進(jìn)行去重了,例如:

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

 這個(gè)代碼將對(duì)myList進(jìn)行去重,只保留唯一的對(duì)象(即,他們的某個(gè)屬性相同)。其中,getSomeProperty是MyObject類中的一個(gè)方法,它返回用于去重的屬性

2.一行代碼完成

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

這段代碼使用Java 8中的流API將一個(gè)ArrayList<BasicSectionCfg>進(jìn)行去重并轉(zhuǎn)換成另一個(gè)ArrayList。

具體來說,大致可以分為以下幾步:

  • 使用stream()方法將原始的ArrayList<BasicSectionCfg>轉(zhuǎn)換成一個(gè)流Stream<BasicSectionCfg>。
  • 使用collect()方法將流Stream<BasicSectionCfg>收集并轉(zhuǎn)換成另一個(gè)集合。collect()方法接收一個(gè)Collector對(duì)象,并且Collectors類中提供了許多預(yù)定義的Collector實(shí)現(xiàn),方便我們使用。在本段代碼中,我們使用了Collectors.collectingAndThen()方法,它將一個(gè)Collector轉(zhuǎn)換成另一個(gè)Collector,并在最后的結(jié)果上進(jìn)行一些操作。
  • 在Collectors.collectingAndThen()方法中,我們傳遞了兩個(gè)參數(shù):

    第一個(gè)參數(shù)是Collectors.toCollection()方法,它創(chuàng)建了一個(gè)新的TreeSet集合,該集合使用Comparator.comparing()方法來對(duì)元素進(jìn)行排序。其中Comparator.comparing()方法接收一個(gè)Function參數(shù),該函數(shù)用于提取對(duì)象的某個(gè)屬性,這里我們使用BasicSectionCfg::getPamKey方法來提取BasicSectionCfg對(duì)象的pamKey屬性。

    第二個(gè)參數(shù)是一個(gè)lambda表達(dá)式,它將TreeSet轉(zhuǎn)換成ArrayList集合。具體地,它調(diào)用了ArrayList的構(gòu)造函數(shù),并將TreeSet作為參數(shù)傳遞給構(gòu)造函數(shù)。

最終,這段代碼的作用就是將list中的重復(fù)元素去重,并按照BasicSectionCfg對(duì)象的pamKey屬性進(jìn)行排序,得到一個(gè)新的ArrayList集合。

附:java list中根據(jù)對(duì)象多個(gè)屬性去重方便快捷的方法

關(guān)鍵方法:

List<TestBean> distinctClass = list1.stream()
.collect(Collectors.collectingAndThen(Collectors.toCollection(
() -> new TreeSet<>(Comparator.comparing(
o -> o.getListName() + ";" + o.getName() + ";" + o.getXxName()))), ArrayList::new));

測(cè)試代碼:

public static void main(String[] args) {
    TestBean testBean = new TestBean();
    List<TestBean> list1 = new ArrayList<>();
    testBean = new TestBean();
    testBean.setName("3");
    testBean.setListName("3");
    testBean.setXxName("3");
    list1.add(testBean);
    testBean = new TestBean();
    testBean.setName("1");
    testBean.setListName("1");
    testBean.setXxName("1");
    list1.add(testBean);
    testBean = new TestBean();
    testBean.setName("2");
    testBean.setListName("2");
    testBean.setXxName("2");
    list1.add(testBean);
    testBean = new TestBean();
    testBean.setName("2");
    testBean.setListName("2");
    testBean.setXxName("2");
    list1.add(testBean);
    System.out.println("原list大?。? + list1.size());
    List<TestBean> distinctClass = list1.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(o -> o.getListName() + ";" + o.getName() + ";" + o.getXxName()))), ArrayList::new));
    System.out.println("去重后的list大?。? + distinctClass.size());
}

輸出結(jié)果如下:

原list大小:4
去重后的list大?。?

總結(jié)

到此這篇關(guān)于java中List&lt;對(duì)象&gt;如何根據(jù)對(duì)象的一個(gè)屬性進(jìn)行去重的文章就介紹到這了,更多相關(guān)java List&lt;對(duì)象&gt;去重內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論