java list 比較詳解及實例
java list 比較詳解及實例
java里比較兩個list的值是否一致,不考慮順序,有多種方法,比如排序后直接用equals比較,相互之間執(zhí)行兩次containsAll等,這些辦法都需要我們給list的元素類實現(xiàn)equals和hashcode方法。但是有一種特殊情況,如果我們并不方便去實習類的equals方法,例如是一個古老的第三方jar包,改代碼會帶來很多未知問題,這時候該怎么辦呢。
其實很簡單,萬能的apache-commons早就想到了這一點,所以在commons-collections4中增加了外部輸入equals和hashcode的方法,甚至equals和hashcode方法本身也不需要我們自己寫代碼,可以用comons-lang包實現(xiàn),具體代碼如下
<dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-collections4</artifactId> <version>4.1</version> </dependency> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.5</version> </dependency> public static <T> boolean isEqualCollection(Collection<T> l1, Collection<T> l2, final String... exludedFields) { Equator<T> equator = generateEquator(exludedFields); return CollectionUtils.isEqualCollection(l1, l2, equator); }
private static <T> Equator<T> generateEquator(final String... exludedFields) { Equator<T> equator = new Equator<T>() { @Override public boolean equate(T o1, T o2) { if (o1 == null && o2 == null) { return true; } if (o1 == null || o2 == null) { return false; } if (o1.getClass() != o2.getClass()) { return false; } return EqualsBuilder.reflectionEquals(o1, o2, exludedFields); } @Override public int hash(T o) { return HashCodeBuilder.reflectionHashCode(o, exludedFields); } }; return equator; }
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
Java在排序數(shù)組中查找元素的第一個和最后一個位置的方法詳解
相信大家在操作Java的時候經常會要在一個數(shù)組(無序)中查找元素的第一個和最后一個位置,下面這篇文章主要給大家介紹了關于Java在排序數(shù)組中查找元素的第一個和最后一個位置的相關資料,需要的朋友可以參考下2024-01-01淺談Spring學習之request,session與globalSession作用域
這篇文章主要介紹了Spring學習之request,session與globalSession作用域的相關內容,需要的朋友可以參考下。2017-09-09java實現(xiàn)基于TCP協(xié)議網絡socket編程(C/S通信)
這篇文章主要介紹了java實現(xiàn)基于TCP協(xié)議網絡socket編程(C/S通信),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-10-10SpringCloud Config分布式配置中心使用教程介紹
springcloud config是一個解決分布式系統(tǒng)的配置管理方案。它包含了 client和server兩個部分,server端提供配置文件的存儲、以接口的形式將配置文件的內容提供出去,client端通過接口獲取數(shù)據(jù)、并依據(jù)此數(shù)據(jù)初始化自己的應用2022-12-12