Fed*_*rer 7 python java hashmap equivalent
在Python中,您可以在字典中使用键值对,您可以在其中循环它们,如下所示:
for k,v in d.iteritems():
print k,v
Run Code Online (Sandbox Code Playgroud)
有没有办法用Java HashMaps做到这一点?
Ric*_*arn 20
是的 - 例如:
Map<String, String> map = new HashMap<String, String>();
// add entries to the map here
for (Map.Entry<String, String> entry : map.entrySet()) {
String k = entry.getKey();
String v = entry.getValue();
System.out.printf("%s %s\n", k, v);
}
Run Code Online (Sandbox Code Playgroud)
如答案所示,基本上有两种方法可以迭代a Map(Map<String, String>在这些例子中假设).
for (Entry<String, String> entry : map.entrySet()) {
System.out.println(entry.getKey() + "=" + entry.getValue());
}
Run Code Online (Sandbox Code Playgroud)迭代Map#keySet()然后Map#get()用来获取每个键的值:
for (String key : map.keySet()) {
System.out.println(key + "=" + map.get(key));
}
Run Code Online (Sandbox Code Playgroud)第二个可能更具可读性,但它具有不必要地调用get()每次迭代的性能成本.有人可能认为创建键集迭代器的成本较低,因为它不需要考虑值.但不管你信不信,keySet().iterator() 创建并使用相同的迭代器entrySet().iterator().唯一的区别是,如果迭代器keySet()的next()调用返回it.next().getKey()而不是it.next().
这个AbstractMap#keySet()javadoc证明了这一点:
子类的迭代器方法在此映射的
entrySet()迭代器上返回一个"包装器对象" .
该AbstractMap源代码也证明了这一点.这是keySet()方法的摘录(在Java 1.6中的第300行左右):
public Iterator<K> iterator() {
return new Iterator<K>() {
private Iterator<Entry<K,V>> i = entrySet().iterator(); // <-----
public boolean hasNext() {
return i.hasNext();
}
public K next() {
return i.next().getKey(); // <-----
}
public void remove() {
i.remove();
}
};
}
Run Code Online (Sandbox Code Playgroud)
请注意,可读性应优先于过早优化,但重要的是要记住这一点.
| 归档时间: |
|
| 查看次数: |
4604 次 |
| 最近记录: |