您好,登錄后才能下訂單哦!
小編給大家分享一下如何判斷List和Map是否相等并合并List中相同的Map,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
List、Set、Map判斷兩個對象相等的標準
List:通過equals()方法比較返回true即可。
HashSet:先比較兩個對象hashCode()方法返回的值是否相等,如果不相等就認為兩個對象是不相等的,如果兩個對象的hashCode相等就繼續調用equals()方法進一步判斷兩個對象是否相等,如果equals()方法返回true認為兩個對象相等,返回false認為兩個對象不相等。
TreeSet:兩個對象通過compareTo(Object obj)方法比較是否返回0:如果返回0,則認為相等,否則不相等。
HashMap、HashTable:(1)兩個key通過equals()方法比較返回true,兩個key的hashCode值也相等;(2)value與另外一個對象通過equals()方法比較返回true即可。
TreeMap:兩個key值通過compareTo()方法返回0,TreeMap即認為這兩個key是相等的。
/** * 根據特定規格,判斷兩個Map是否相等 */ private static boolean isEquals(Map<String, String> src, Map<String, String> dest, String[] samekey) { boolean equals = true; StringBuffer sbf_src = new StringBuffer(); StringBuffer sbf_dest = new StringBuffer(); for (int i = 0; i < samekey.length; i++) { sbf_src.append(src.get(samekey[i])); sbf_dest.append(dest.get(samekey[i])); } if (sbf_src.toString().equals(sbf_dest.toString())) { equals = true; } else { equals = false; } return equals; } /** * 獲得list中有沒有相同的keyMap(待需找的map)<br> * 如果找到則返回這個list和keyMap相同Map的下標,否則返回-1 */ private static int getEqualsMap(List<Map<String, String>> list, Map<String, String> keyMap, String[] samekey) { int equalsIndex = -1; for (int i = 0; i < list.size(); i++) { Map<String, String> tempMap = list.get(i); if (isEquals(tempMap, keyMap, samekey)) { equalsIndex = i; } } return equalsIndex; } /** * 合并List中相同的Map * @param list * @return */ public static List<Map<String, String>> combineList(List<Map<String, String>> list, String[] samekey,String combinekey) { List<Map<String, String>> retList = new ArrayList<Map<String, String>>(); for (int i = 0; i < list.size(); i++) { Map<String, String> tempMap = list.get(i); int equalsIndex = getEqualsMap(retList, tempMap, samekey); if (-1 == equalsIndex) { retList.add(tempMap); } else { String custSrc = retList.get(equalsIndex).get(combinekey); int custSrcInt = Integer.parseInt(custSrc.substring(0, custSrc.length() - 1)); String custTemp = tempMap.get(combinekey); int custTempInt = Integer.parseInt(custTemp.substring(0, custTemp.length() - 1)); String destCust = (custSrcInt + custTempInt) + custSrc.substring(custSrc.length() - 1); retList.get(equalsIndex).put(combinekey, destCust); } } return retList; }
看完了這篇文章,相信你對“如何判斷List和Map是否相等并合并List中相同的Map”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。