欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java读取Map的两种方法与对比

程序员文章站 2024-03-12 09:51:38
前言 在java中遍历map有不少的方法。这篇文章我们就来看一下java读取map的两种方法以及这两种方法的对比。 一、 遍历map方法a ma...

前言

在java中遍历map有不少的方法。这篇文章我们就来看一下java读取map的两种方法以及这两种方法的对比。

一、 遍历map方法a

map map = new hashmap(); 
iterator iter = map.entryset().iterator(); 
while (iter.hasnext()) { 
 map.entry entry = (map.entry) iter.next(); 
 object key = entry.getkey(); 
 object val = entry.getvalue(); 
} 

二、遍历map方法b

map map = new hashmap(); 
iterator iter = map.keyset().iterator(); 
while (iter.hasnext()) { 
 object key = iter.next(); 
  object val = map.get(key); 
} 

三、分析遍历方法

   方法a:  在遍历中一次读取map.entry,然后直接获取的值。

   方法b:   基于keyset则是,先遍历,然后再从map中读取信息。

四、性能测试

import java.util.hashmap; 
import java.util.iterator; 
import java.util.map; 
 
import org.junit.beforeclass; 
import org.junit.test; 
 
public class maploopa { 
 private static map<integer, string> infos = new hashmap<integer, string>(); 
 
 @beforeclass 
 public static void setup() { 
 for (int i=0; i<1000000; i++) { 
  infos.put(i, "test information" + i); 
 } 
 system.out.println("setup is done."); 
 } 
 
 @test 
 public void testmaploopa() { 
 iterator<map.entry<integer, string>> iterator = infos.entryset().iterator(); 
 long starttime = system.currenttimemillis(); 
 while (iterator.hasnext()) { 
  map.entry<integer, string> entry = iterator.next(); 
  int key = entry.getkey(); 
  string val = entry.getvalue(); 
 } 
  
 system.out.println("a solution takes in looping map with 1000000 entries:" 
   + (system.currenttimemillis()-starttime) + " milli seconds"); 
 } 
 
 @test 
 public void testmaploopb() { 
 iterator<integer> iterator = infos.keyset().iterator(); 
 long starttime = system.currenttimemillis(); 
 while (iterator.hasnext()) {  
  int key = iterator.next(); 
  string val = infos.get(key); 
 } 
  
 system.out.println("b solution takes in looping map with 1000000 entries:" + 
   (system.currenttimemillis()-starttime) + " milli seconds"); 
 } 
} 

测试结果:

Java读取Map的两种方法与对比 

由此可见,在map中存放1000000个数据,并在此数据集合中,进行遍历。效率上差异将近1倍的性能差异。

五、总结

好了,以上就是这篇文章的全部内容了,可以看车方法a的效率总体要高一些。一般推荐大家使用方法a。希望本文的内容对大家的学习或者工作能带来一定的帮助。