Как сравнить два хэш-карты?

Как сравнить значения в обеих хэш-картах с помощью клавиш? Поскольку ключи идентичны, а значения are'nt. и возвращать логический результат для каждого сравнения ключей. как:

map1=[1,res]
[2,tr]
[3,677]
[4,cv]  

map2=[1,res]
[2,cd]
[3,677]
[4,fs]

Он должен вернуть мне

true
false
true
false

Ответы

Ответ 1

Здесь используется метод, который генерирует карту результатов (Map of key to boolean). Он будет хорошо воспроизводиться независимо от разных ключей и порядка сортировки ключей:

/**
 * Works with any two maps with common key / value types.
 * The key type must implement Comparable though (for sorting).
 * Returns a map containing all keys that appear in either of the supplied maps.
 * The values will be true if and only if either
 *   - map1.get(key)==map2.get(key) (values may be null) or
 *   - map1.get(key).equals(map2.get(key)).
 */
public static <K extends Comparable<? super K>, V>
Map<K, Boolean> compareEntries(final Map<K, V> map1,
    final Map<K, V> map2){
    final Collection<K> allKeys = new HashSet<K>();
    allKeys.addAll(map1.keySet());
    allKeys.addAll(map2.keySet());
    final Map<K, Boolean> result = new TreeMap<K, Boolean>();
    for(final K key : allKeys){
        result.put(key,
            map1.containsKey(key) == map2.containsKey(key) &&
            Boolean.valueOf(equal(map1.get(key), map2.get(key))));
    }
    return result;
}

private static boolean equal(final Object obj1, final Object obj2){
    return obj1 == obj2 || (obj1 != null && obj1.equals(obj2));
}

Использование:

public static void main(final String[] args){
    final Map<Integer, String> map1 = new HashMap<Integer, String>();
    map1.put(1, null);
    map1.put(2, "Different");
    map1.put(3, "Same");
    map1.put(4, "First Map only");
    final Map<Integer, String> map2 = new HashMap<Integer, String>();
    map2.put(3, "Same");
    map2.put(1, null);
    map2.put(2, "Yup, different");
    map2.put(5, "Second Map only");
    final Map<Integer, Boolean> comparisonResult =
        compareEntries(map1, map2);
    for(final Entry<Integer, Boolean> entry : comparisonResult.entrySet()){
        System.out.println("Entry:" + entry.getKey() + ", value: "
            + entry.getValue());
    }

}

Вывод:

Запись: 1, значение: true
Запись: 2, значение: ложное
Запись: 3, значение: true
Запись: 4, значение: false
Запись: 5, значение: false

Ответ 3

Предполагая, что у вас есть одинаковые наборы записей:

import java.util.HashMap;
import java.util.Map.Entry;

public class HashMapComparison {

    public static void main(String[] args) {

        HashMap<Integer, String> map1 = new HashMap<Integer, String>();
        map1.put(1, "res");
        map1.put(2, "tr");

        HashMap<Integer, String> map2 = new HashMap<Integer, String>();
        map2.put(1, "res");
        map2.put(2, "cd");

        for (Entry<Integer, String> entry : map1.entrySet()) {
            Integer key = entry.getKey();
            System.out.println("key " + key + ": "
                    + entry.getValue().equals(map2.get(key)));
        }

    }

}

Ответ 4

Вы можете взять ключи одной карты (с помощью метода keySet()), итерации через них, получения значений с обеих карт (с помощью get() и сравнить их.

Кроме того, вы можете использовать метод values ​​(), чтобы все пары ключ-значение формировали одну карту, повторяли ее и сравнивали значения со значениями с другой карты.

Ответ 5

Псевдокод:

HashMap map1;
HashMap map2;
HashMap resultMap;
for(KeyType key : map1.keySet() ) {
  if(map1.get(key).equals(map2.get(key)){
    resultMap.put(key,true);
  } else {
    resultMap.put(key,false);
  }   

}

Ответ 6

Map map = new HashMap();
map.put("AA","aaa");
map.put("BB","bbb");
map.put("CC","ccc");
map.put("DD","ddd");

Map map2 = new HashMap();
map2.put("BB","bbb");
map2.put("AA","aaa");
map2.put("DD","ddd");
map2.put("CC","ccc");

if(map.equals(map2))
{
    System.out.println("Eql");
}
else
{
    System.out.println("Not");
}

Ответ 7

использование:

mapA.equals(mapB);

Это приведет к возврату логического результата.