Programing

TreeMap을 반복하는 방법?

lottogame 2020. 7. 2. 07:51
반응형

TreeMap을 반복하는 방법? [복제]


가능한 중복 :
지도의 각 항목을 어떻게 반복합니까?

을 반복 TreeMap하고 특정 값을 가진 모든 키에 대해 새로운 키를 추가하고 싶습니다 TreeMap. 어떻게해야합니까?


TreeMap <String, Integer> 유형을 가정합니다.

for(Map.Entry<String,Integer> entry : treeMap.entrySet()) {
  String key = entry.getKey();
  Integer value = entry.getValue();

  System.out.println(key + " => " + value);
}

(키 및 값 유형은 모든 클래스가 될 수 있습니다)


    //create TreeMap instance
    TreeMap treeMap = new TreeMap();

    //add key value pairs to TreeMap
    treeMap.put("1","One");
    treeMap.put("2","Two");
    treeMap.put("3","Three");

    /*
      get Collection of values contained in TreeMap using
      Collection values()        
    */
    Collection c = treeMap.values();

    //obtain an Iterator for Collection
    Iterator itr = c.iterator();

    //iterate through TreeMap values iterator
    while(itr.hasNext())
      System.out.println(itr.next());

또는:

   for (Map.Entry<K,V> entry : treeMap.entrySet()) {
        V value = entry.getValue();
        K key = entry.getKey();
   }

또는:

   // Use iterator to display the keys and associated values
   System.out.println("Map Values Before: ");
   Set keys = map.keySet();
   for (Iterator i = keys.iterator(); i.hasNext();) {
     Integer key = (Integer) i.next();
     String value = (String) map.get(key);
     System.out.println(key + " = " + value);
   }

모든 맵을 반복하는 일반적인 방법을 지적하십시오.

 private <K, V> void iterateOverMap(Map<K, V> map) {
    for (Map.Entry<K, V> entry : map.entrySet()) {
        System.out.println("key ->" + entry.getKey() + ", value->" + entry.getValue());
    }
    }

K가 키 유형이라고 가정 하면 Google 컬렉션을 사용 합니다.

Maps.filterKeys(treeMap, new Predicate<K>() {
  @Override
  public boolean apply(K key) {
    return false; //return true here if you need the entry to be in your new map
  }});

filterEntries값이 필요한 경우 대신 사용할 수 있습니다 .

참고 URL : https://stackoverflow.com/questions/1318980/how-to-iterate-over-a-treemap

반응형