Java 해시맵의 값에서 키 검색
Java HashMap에서 특정 값에 해당하는 키를 검색하는 것은 다양한 시나리오에서 유용할 수 있습니다. . 다음은 이 작업을 수행하는 방법에 대한 포괄적인 탐색입니다.
루프 기반 접근 방식:
값에서 키를 얻는 전통적인 방법은 HashMap의 항목. 각 항목에 대해 값을 원하는 값과 비교하십시오. 일치하는 항목이 발견되면 해당 키를 검색할 수 있습니다.
public static <T, E> Set<T> getKeysByValue(Map<T, E> map, E value) { Set<T> keys = new HashSet<>(); for (Entry<T, E> entry : map.entrySet()) { if (Objects.equals(value, entry.getValue())) { keys.add(entry.getKey()); } } return keys; }
일대일 매핑을 위한 키 검색:
각 값이 매핑되는 시나리오에서 하나의 키에만 루프 기반 접근 방식을 단순화하여 첫 번째 일치하는 키를 반환할 수 있습니다. key.
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; }
Java 8 스트림 접근 방식:
Java 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:
또는 Guava 라이브러리 사용자에게는 BiMap 데이터 구조가 특히 유용할 수 있습니다. 키와 값 사이의 양방향 매핑을 제공하여 키와 값 모두를 효율적으로 검색할 수 있습니다.
BiMap<Token, Character> tokenToChar = ImmutableBiMap.of(Token.LEFT_BRACKET, '[', Token.LEFT_PARENTHESIS, '('); Token token = tokenToChar.inverse().get('('); Character c = tokenToChar.get(token);
위 내용은 Java HashMap의 값에서 키를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!