You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

SimpleLruCacheBenchmark.java 2.2KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /*
  2. * Copyright (C) 2019, Matthias Sohn <matthias.sohn@sap.com> and others
  3. *
  4. * This program and the accompanying materials are made available under the
  5. * terms of the Eclipse Distribution License v. 1.0 which is available at
  6. * https://www.eclipse.org/org/documents/edl-v10.php.
  7. *
  8. * SPDX-License-Identifier: BSD-3-Clause
  9. */
  10. package org.eclipse.jgit.benchmarks;
  11. import java.security.SecureRandom;
  12. import java.util.concurrent.TimeUnit;
  13. import org.eclipse.jgit.util.SimpleLruCache;
  14. import org.openjdk.jmh.annotations.Benchmark;
  15. import org.openjdk.jmh.annotations.BenchmarkMode;
  16. import org.openjdk.jmh.annotations.Group;
  17. import org.openjdk.jmh.annotations.GroupThreads;
  18. import org.openjdk.jmh.annotations.Mode;
  19. import org.openjdk.jmh.annotations.OutputTimeUnit;
  20. import org.openjdk.jmh.annotations.Scope;
  21. import org.openjdk.jmh.annotations.Setup;
  22. import org.openjdk.jmh.annotations.State;
  23. import org.openjdk.jmh.annotations.TearDown;
  24. import org.openjdk.jmh.runner.Runner;
  25. import org.openjdk.jmh.runner.RunnerException;
  26. import org.openjdk.jmh.runner.options.Options;
  27. import org.openjdk.jmh.runner.options.OptionsBuilder;
  28. @State(Scope.Benchmark)
  29. public class SimpleLruCacheBenchmark {
  30. SecureRandom rnd = new SecureRandom();
  31. private volatile SimpleLruCache<String, String> cache = new SimpleLruCache<>(
  32. 100, 0.2f);
  33. private volatile int i;
  34. @Setup
  35. public void setupBenchmark() {
  36. i = rnd.nextInt(250);
  37. }
  38. @TearDown
  39. public void teardown() {
  40. cache = null;
  41. }
  42. @Benchmark
  43. @Group("readwrite")
  44. @GroupThreads(1)
  45. @BenchmarkMode({ Mode.AverageTime })
  46. @OutputTimeUnit(TimeUnit.NANOSECONDS)
  47. public SimpleLruCache<String, String> testCacheWrite() {
  48. cache.put("k" + i, "v" + i);
  49. return cache;
  50. }
  51. @Benchmark
  52. @Group("readwrite")
  53. @GroupThreads(1)
  54. @BenchmarkMode({ Mode.AverageTime })
  55. @OutputTimeUnit(TimeUnit.NANOSECONDS)
  56. public SimpleLruCache<String, String> testCacheRead() {
  57. cache.get("k" + i);
  58. return cache;
  59. }
  60. public static void main(String[] args) throws RunnerException {
  61. Options opt = new OptionsBuilder()
  62. .include(SimpleLruCacheBenchmark.class.getSimpleName())
  63. // .addProfiler(StackProfiler.class)
  64. // .addProfiler(GCProfiler.class)
  65. .forks(1).jvmArgs("-ea").build();
  66. new Runner(opt).run();
  67. }
  68. }