番石榴CacheBuilder性能

时间:2013-03-20 00:51:56

标签: java guava

以下微基准测试使用Guava CacheBuilder。它的执行速度比ConcurrentHashMap慢1个数量级。我正确使用CacheBuilder吗?

    final Cache c = CacheBuilder.newBuilder().concurrencyLevel(10).maximumSize(100).build();
    int num = 10;
    final java.util.concurrent.CountDownLatch startSignal = new java.util.concurrent.CountDownLatch(1);
    final java.util.concurrent.CountDownLatch doneSignal = new java.util.concurrent.CountDownLatch(num);
    int j = 0;
    final Long[] pairs = new Long[] { new Long(5),
            new Long(324235342L), new Long(3242385842L), new Long(8463242363642L),
            new Long(3244532342L), new Long(54654L), new Long(7332742342L),
            new Long(32425345342L), new Long(32453662342L), new Long(63573242342L) };
    Object state = new Object();

    for (Long p : pairs) {
        c.put(p, state);
    }
    Thread [] threads = new Thread[num];
    for (int k = 0 ; k < num ; ++k) {
        final int z = k;
        threads[k] = new Thread(new Runnable() {
            int i = z;
            @Override
            public void run() {
                try {
                    startSignal.await();
                    for (int j = 0 ; j < 100000 ; ++j) {
                        c.getIfPresent(pairs[z]);
                    }
                    doneSignal.countDown();
                } catch (Exception e) {
                    e.printStackTrace();
                }

            }
        });
    }
    for (Thread t : threads) {
        t.start();
    }
    startSignal.countDown();
    c.getIfPresent(pairs[1]);
    long t = System.currentTimeMillis();
    doneSignal.await();
    System.out.println("done in " + (System.currentTimeMillis() - t));

ConcurrentHashMap给了我9毫秒。 CacheBuilder给了我90毫秒。这是在将相同的代码循环几分钟之后。

0 个答案:

没有答案