重複の可能性:
マップ内の各エントリを反復するにはどうすればよいですか?
を反復処理したいのですTreeMap
が、特定の値を持つすべてのキーについて、それらを新しい に追加したいと考えています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());
}
}
Using Google Collections, assuming K is your key type:
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
}});
You can use filterEntries
instead if you need the value as well.