যদি আপনার ডেটা স্ট্রাকচারটিতে কী এবং মানগুলির মধ্যে একাধিক টু ওয়ান ম্যাপিং থাকে তবে আপনাকে এন্ট্রিগুলি দিয়ে পুনরাবৃত্তি করতে হবে এবং সমস্ত উপযুক্ত কী বেছে নেওয়া উচিত:
public static <T, E> Set<T> getKeysByValue(Map<T, E> map, E value) {
Set<T> keys = new HashSet<T>();
for (Entry<T, E> entry : map.entrySet()) {
if (Objects.equals(value, entry.getValue())) {
keys.add(entry.getKey());
}
}
return keys;
}
ক্ষেত্রে একের সাথে এক সম্পর্ক, আপনাকে প্রথমে মিলেছে কী আসতে পারেন:
public static <T, E> T getKeyByValue(Map<T, E> map, E value) {
for (Entry<T, E> entry : map.entrySet()) {
if (Objects.equals(value, entry.getValue())) {
return entry.getKey();
}
}
return null;
}
জাভা 8 তে:
public static <T, E> Set<T> getKeysByValue(Map<T, E> map, E value) {
return map.entrySet()
.stream()
.filter(entry -> Objects.equals(entry.getValue(), value))
.map(Map.Entry::getKey)
.collect(Collectors.toSet());
}
এছাড়াও, পেয়ারা ব্যবহারকারীদের জন্য, বিম্যাপ কার্যকর হতে পারে। উদাহরণ স্বরূপ:
BiMap<Token, Character> tokenToChar =
ImmutableBiMap.of(Token.LEFT_BRACKET, '[', Token.LEFT_PARENTHESIS, '(');
Token token = tokenToChar.inverse().get('(');
Character c = tokenToChar.get(token);