java 判断map相等_判断List和Map是否相等并合并List中相同的Map

本文介绍了Java中List、Set、Map判断两个对象相等的标准。List通过equals方法,HashSet先比hashCode再用equals,TreeSet用compareTo方法。还给出判断两个Map相等的方法,以及在List中查找相同Map、合并List中相同Map的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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 src, Map 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)

* 如果找到则返回这个list和keyMap相同Map的下标,否则返回-1

*/

private static int getEqualsMap(List> list, Map keyMap, String[] samekey) {

int equalsIndex = -1;

for (int i = 0; i < list.size(); i++) {

Map tempMap = list.get(i);

if (isEquals(tempMap, keyMap, samekey)) {

equalsIndex = i;

}

}

return equalsIndex;

}

/**

* 合并List中相同的Map

* @param list

* @return

*/

public static List> combineList(List> list, String[] samekey,String combinekey) {

List> retList = new ArrayList>();

for (int i = 0; i < list.size(); i++) {

Map 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;

}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值