例如:
keyStore {key1=>value1}
nodeMap {key1=>value1, key2=>value2}
return true
----
keyStore {key1=>value1, key2=>value2}
nodeMap {key1=>value1, key2=>value2}
return true
----
keyStore {key1=>value1, key3=>value3}
nodeMap {key1=>value1, key2=>value2}
return false;
----
keyStore {key1=>value1, key3=>value3}
nodeMap {key1=>value1, key2=>value2, key3=>value3}
return true;
代码:
private boolean checkForMatch(NamedNodeMap nodeMap, Map<String, String> keyStore)
{
boolean foundMatch = false;
for (int i = 0; i < nodeMap.getLength(); i++)
{
Node node = nodeMap.item(i);
String nodeName = node.getNodeName();
if (keyStore.containsKey(nodeName))
{
if (keyStore.get(nodeName).contains(node.getNodeValue()))
{
foundMatch = true;
}
else
{
foundMatch = false;
break;
}
}
}
return foundMatch;
}
这不会有多种原因,例如,当nodeMap由许多键值对组成,但keyStore只包含一个键值对,而第一个条件失败则循环中断,而不是继续。
答案 0 :(得分:2)
我能想到的最简单易读的方法包括将您的NamedNodeMap
实例转换为实际Map<String, String>
,然后使用标准Set.containsAll
方法执行您想要的检查:
private boolean checkForMatch(NamedNodeMap nodeMap, Map<String, String> keyStore) {
// First create map from nodeMap
Map<String, String> nodes = new HashMap<>();
for (int i = 0; i < nodeMap.getLength(); i++) {
Node node = nodeMap.item(i);
nodes.put(node.getNodeName(), node.getNodeValue());
}
// Then check the condition
return nodes.entrySet().containsAll(keyStore.entrySet());
}
您可以使用流来实现一行:
private boolean checkForMatch(NamedNodeMap nodeMap, Map<String, String> keyStore) {
return IntStream.range(0, nodeMap.getLength())
.mapToObj(nodeMap::item)
.collect(Collectors.toMap(Node::getNodeName, Node::getNodeValue))
.entrySet().containsAll(keyStore.entrySet());
}
两个片段在功能上都是等效的。
答案 1 :(得分:1)
让我们尽量不要使事情复杂化,您只需要检查keyStore
中是否存在nodeMap
中的所有元素。
<强>步骤:强>
这是一种简单的方法:
if(keyStore.size() > nodeMap.getLength())
return false;
int count = 0;
for (String key: keyStore.keySet())
{
if(keyStore.get(key) != nodeMap.item(count).getNodeValue())
return false;
}
return true;