【发布时间】:2015-11-14 18:36:59
【问题描述】:
在高层次上,我正在尝试比较 2 个字符串映射的值
Map 1: [{ExpID1, SomeExpValue1}, {ExpID2, SomeExpValue2}, ...]
Map 2: [{FriID1, SomeFriValue1}, {FriID1, SomeFriValue2}, ...]
所以最终,我希望我的比较是这样的:
须藤代码:
if ( ExpID1.equals(FriID1) ) {
Assert.AssertEquals(SomeExpValue1, SomeFriValue1, "Library element does not match!")
}
但是,由于这些是地图,因此需要进行一些循环。我真正的问题在这里,我怎样才能正确有效地循环没有更多的嵌入式 foreach 或 forloops。这些似乎超级昂贵。我觉得我当前的循环在某种程度上是错误的或非常昂贵。任何帮助或帮助将不胜感激。
目前我拥有的是这样的:
@Test
public void testIntegration() throws Exception {
// Get all files in directory
File[] files = getFilesInFolder(friendlyNamesDir);
String linkedResp = FileUtils.readFileToString(new File(explanationResponsePath));
Map<String, String> map1 = getIDTitleMapExpResponse(linkedResp, "node");
int counter = 1;
for(File f : files) {
if(f.length() == 0) throw new Exception("File does not exist...");
for(String expID : map1.keySet()) {
logger.info("Exp ID: "+expID);
Map<String, String> map2 = getIDNameMapFromFriendly(f.getCanonicalPath());
for(String friendlyID : map2.keySet()) {
logger.info(counter+" - Friendly ID: "+friendlyID+" Name: "+map2.get(friendlyID));
if(friendlyID.equals(expID)) {
Assert.assertEquals(map1.get(friendlyID), map2.get(expID));
}
counter++;
}
}
}
}
【问题讨论】:
-
map的key集合的交集就是要迭代的集合,如果map 1的值和map 2的值相等,那么对于所有的迭代值,你的条件都是true。 (我知道地图 1 中可能有键,而不是地图 2,反之亦然。如果没有,请澄清。)
-
@laune 是的,总结得差不多了。我想单独比较地图的值,因此是 foreach 循环。
-
好的,所以我认为这不仅仅是 map1.equals(map2)...
-
我要做的是循环遍历 2 个地图的 ID,如果 map1 的当前 ID 与 map2 匹配,则比较它们的值(断言它们相等)
标签: java data-structures collections compare assert