可能性の重複:
How do I iterate over each Entry in a Map?TreeMapを反復処理する方法は?
私はTreeMap
を反復処理したい、と特定の値を持つすべてのキーのために、私は彼らが新しいTreeMap
に追加することにしたいです。これどうやってするの?
可能性の重複:
How do I iterate over each Entry in a Map?TreeMapを反復処理する方法は?
私はTreeMap
を反復処理したい、と特定の値を持つすべてのキーのために、私は彼らが新しいTreeMap
に追加することにしたいです。これどうやってするの?
型ツリーマップを<文字列、整数>と仮定:
for(Map.Entry<String,Integer> entry : treeMap.entrySet()) {
String key = entry.getKey();
Integer value = entry.getValue();
System.out.println(key + " => " + value);
}
を(キーと値のタイプは、任意のCLASとすることができますGoogle Collectionsを使用して、もちろんS)
//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);
}
、Kはあなたのキータイプであると仮定すると:
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
を使用することができます。
これはソートを行いません。 – zyamys
ただのマップを反復処理する一般的な方法を指摘する:
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());
}
}
@Click:」特定の値を持っている...すべてのための「キーの...」。指定されたSetのすべてのキー、または指定された述語を満たすすべてのキーを意味しますか? –