자바 가 맵 을 읽 는 두 가지 방법 과 비교

2752 단어 자바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(); 
} 
2.지 도 를 옮 겨 다 니 는 방법 B

Map map = new HashMap(); 
Iterator iter = map.keySet().iterator(); 
while (iter.hasNext()) { 
 Object key = iter.next(); 
  Object val = map.get(key); 
} 
3.분석 스 트 리밍 방법
   방법 A:  옮 겨 다 니 는 동안 읽 기Map.Entry그리고 직접 가 져 온 값 입 니 다.
   방법 B:   키 세트 를 기반 으로 한 것 은 먼저 옮 겨 다 니 고 맵 에서 정 보 를 읽 는 것 이다.
성능 테스트

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"); 
 } 
} 
테스트 결과:
 
이 를 통 해 알 수 있 듯 이 Map 에 1000000 개의 데 이 터 를 저장 하고 이 데이터 집합 에서 옮 겨 다 닌 다.효율 적 차이 가 1 배 에 가 까 운 성능 차이.
총화
자,이상 이 이 글 의 전체 내용 입 니 다.차 방법 A 의 효율 이 전체적으로 높 아야 합 니 다.일반적으로 여러분 의 사용법 A 를 추천 합 니 다.본 논문 의 내용 이 여러분 의 학습 이나 업무 에 어느 정도 도움 이 되 기 를 바 랍 니 다.

좋은 웹페이지 즐겨찾기