私は、Kotlinを使ってより機能的なスタイルで入れ子になったハッシュマップを反復しようとしています。特に、2つのHashMapインスタンス(どちらもタイプMap<String, Integer>
)があり、いくつかの基準に基づいて値を一致させたいと思います。ここで私が達成したいもののJavaメソッドは次のとおりです。ここでKotlinのネストされたハッシュマップ反復で `filterValues`を使用するにはどうすればよいですか?
Map<Integer, Integer> pairs = new LinkedHashMap<>();
for (Map.Entry<String, Integer> oldImages : startingImageMap.entrySet()) {
for (Map.Entry<String, Integer> newImages : finalImageMap.entrySet()) {
Integer oldImageVal = oldImages.getValue();
Integer newImageVal = newImages.getValue();
boolean containsNewType = pairs.containsKey(newImageVal) &&
pairs.get(newImageVal).intValue() == oldImageVal.intValue();
boolean urlsMatch = newImages.getKey().equals(oldImages.getKey());
if (!containsNewType && urlsMatch) {
pairs.put(oldImageVal, newImageVal);
}
}
}
return pairs;
はKotlinで機能的同等物で私の試みです:
private val swapPairs: Map<Int, Int>
get() {
val pairs = LinkedHashMap<Int, Int>()
startingImageMap.forEach {
val finalImageMap = finalImageMap.filterValues {
val containsNewType = pairs.containsKey(it) && pairs[it] == startingImageMap[it]
val urlMatch = it == startingImageMap[it]
return !containsNewType && urlsMatch
}.values.first()
}
return pairs
}
私はfilterValues
を使用して適切にこれを行う方法にこだわっています。 正しいソリューションはKotlinのように見えますか?