本文主要是介绍entrySet 和 keySet 的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
看了网上一些文章,都说keySet比entrySet慢。 我测试下来两者区别不大。而且用keySet更加简单
import java.util.Calendar;
import java.util.*;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map.Entry;
/**
* 测试keySet()与entrySet()的迭代时间 keySet():迭代后只能通过get()取key
* entrySet():迭代后可以e.getKey(),e.getValue()取key和value。返回的是Entry接口
* 最后说明下keySet()的速度比entrySet()慢了很多。看来以后要考虑用entrySet()了
*
* @author YL
* @date 2009.6.10
*/
public class Test {
public static void main(String[] args) {
Map<String, String> kmap = new TreeMap<String, String>();
Map<String, String> emap = new TreeMap<String, String>();
int num = 20000;
// 装数据
for (int i = 0; i < num; i++) {
kmap.put("" + i, "YL");
}
for (int i = 0; i < num; i++) {
emap.put("" + i, "ZT");
}
long stimes = System.currentTimeMillis();
Iterator<String> ktor = kmap.keySet().iterator();
while (ktor.hasNext()) {
String k = ktor.next();
String v = kmap.get(k);
System.out.println(k + v);
}
long stimes1 = System.currentTimeMillis();
Iterator<Entry<String, String>> itor = emap.entrySet().iterator();
while (itor.hasNext()) {
Entry<String, String> e = itor.next();
String k = e.getKey();
String v = e.getValue();
System.out.println(k + v);
}
long stimes2 = System.currentTimeMillis();
System.out.println("keySet: " + (stimes1 - stimes));
System.out.println("entrySet: " + (stimes2 - stimes1));
}
}
这篇关于entrySet 和 keySet 的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!