Java中什么集合查询最快

上一篇文章中,我们了解了ArrayList的的遍历速度比LinkedList快7000多倍。
下面我们看一下什么结合中查询对象最快。呵呵

代码如下:
  1. package dbtransfer;
  2. import java.util.ArrayList;
  3. import java.util.LinkedList;
  4. import java.util.Random;
  5. import java.util.HashMap;
  6. import java.util.HashSet;
  7. public class ListTest {
  8.     private static Random random = new Random();
  9.     public static void main(String[] args){
  10.         ArrayList<String> arraylist = new ArrayList();
  11.         LinkedList<String> linkedlist = new LinkedList();
  12.         HashMap<String,Object> map = new HashMap();
  13.         HashSet<String> set = new HashSet();
  14.         for(int i=0;i<50000;i++){
  15.             String r = randomString();
  16.             arraylist.add(r);
  17.             linkedlist.add(r);
  18.             map.put(r, r);
  19.             set.add(r);
  20.         }
  21.         
  22.         System.out.println("arraylist size "+arraylist.size());
  23.         System.out.println("linkedlist size "+linkedlist.size());
  24.         System.out.println("map size "+map.size());
  25.         System.out.println("set size "+set.size());
  26.         
  27.         
  28.         System.out.println("------");
  29.         long begin = System.currentTimeMillis();
  30.         for(int j=0;j<arraylist.size();j++){
  31.             arraylist.contains(arraylist.get(j));
  32.         }
  33.         System.out.println("arraylist time "+(System.currentTimeMillis()-begin));
  34.         
  35.         
  36.         begin = System.currentTimeMillis();
  37.         for(int j=0;j<arraylist.size();j++){
  38.             linkedlist.contains(arraylist.get(j));
  39.         }
  40.         System.out.println("linkedlist time "+(System.currentTimeMillis()-begin));
  41.         
  42.         begin = System.currentTimeMillis();
  43.         for(int i=0;i<100;i++){
  44.             for(int j=0;j<arraylist.size();j++){
  45.                 map.containsKey(arraylist.get(j));
  46.             }
  47.         }
  48.         System.out.println("map time "+(System.currentTimeMillis()-begin));
  49.         
  50.         begin = System.currentTimeMillis();
  51.         for(int i=0;i<100;i++){
  52.             for(int j=0;j<arraylist.size();j++){
  53.                 set.contains(arraylist.get(j));
  54.             }
  55.         }
  56.         System.out.println("set time "+(System.currentTimeMillis()-begin));
  57.         
  58.     }
  59.     protected static String randomString() {
  60.         return Long.toString(random.nextLong(), 36);
  61.     }
  62. }
在我的机器上,结果如下:
arraylist size 50000
linkedlist size 50000
map size 50000
set size 50000
------
arraylist time 49328
linkedlist time 57641
map time 625
set time 578

可见呀,如果是在集合中查询某个对象是否存在,是HashSet的速度最快,而且比List快将近1万倍。
再次证明了:Java集合不可以乱用呀!




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值