JAVA-12387. Correct/Rename THREADS to TASKS and int threads to int tasks. (#13084)
This commit is contained in:
parent
0e594f1a74
commit
21c42ebebc
|
@ -19,7 +19,7 @@ import org.openjdk.jmh.annotations.Warmup;
|
||||||
@Warmup(iterations = 0)
|
@Warmup(iterations = 0)
|
||||||
public class ConcurrentAccessBenchmark {
|
public class ConcurrentAccessBenchmark {
|
||||||
static final int SLOTS = 4;
|
static final int SLOTS = 4;
|
||||||
static final int THREADS = 10000;
|
static final int TASKS = 10000;
|
||||||
static final int BUCKETS = Runtime.getRuntime().availableProcessors() * SLOTS;
|
static final int BUCKETS = Runtime.getRuntime().availableProcessors() * SLOTS;
|
||||||
SingleLock singleLock = new SingleLock();
|
SingleLock singleLock = new SingleLock();
|
||||||
StripedLock stripedLock = new StripedLock(BUCKETS);
|
StripedLock stripedLock = new StripedLock(BUCKETS);
|
||||||
|
@ -28,27 +28,27 @@ public class ConcurrentAccessBenchmark {
|
||||||
@BenchmarkMode(Mode.Throughput)
|
@BenchmarkMode(Mode.Throughput)
|
||||||
@OutputTimeUnit(TimeUnit.MILLISECONDS)
|
@OutputTimeUnit(TimeUnit.MILLISECONDS)
|
||||||
public Map<String,String> singleLockHashMap() throws InterruptedException {
|
public Map<String,String> singleLockHashMap() throws InterruptedException {
|
||||||
return singleLock.doWork(new HashMap<String,String>(), THREADS, SLOTS);
|
return singleLock.doWork(new HashMap<String,String>(), TASKS, SLOTS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Benchmark
|
@Benchmark
|
||||||
@BenchmarkMode(Mode.Throughput)
|
@BenchmarkMode(Mode.Throughput)
|
||||||
@OutputTimeUnit(TimeUnit.MILLISECONDS)
|
@OutputTimeUnit(TimeUnit.MILLISECONDS)
|
||||||
public Map<String,String> stripedLockHashMap() throws InterruptedException {
|
public Map<String,String> stripedLockHashMap() throws InterruptedException {
|
||||||
return stripedLock.doWork(new HashMap<String,String>(), THREADS, SLOTS);
|
return stripedLock.doWork(new HashMap<String,String>(), TASKS, SLOTS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Benchmark
|
@Benchmark
|
||||||
@BenchmarkMode(Mode.Throughput)
|
@BenchmarkMode(Mode.Throughput)
|
||||||
@OutputTimeUnit(TimeUnit.MILLISECONDS)
|
@OutputTimeUnit(TimeUnit.MILLISECONDS)
|
||||||
public Map<String,String> singleLockConcurrentHashMap() throws InterruptedException {
|
public Map<String,String> singleLockConcurrentHashMap() throws InterruptedException {
|
||||||
return singleLock.doWork(new ConcurrentHashMap<String,String>(), THREADS, SLOTS);
|
return singleLock.doWork(new ConcurrentHashMap<String,String>(), TASKS, SLOTS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Benchmark
|
@Benchmark
|
||||||
@BenchmarkMode(Mode.Throughput)
|
@BenchmarkMode(Mode.Throughput)
|
||||||
@OutputTimeUnit(TimeUnit.MILLISECONDS)
|
@OutputTimeUnit(TimeUnit.MILLISECONDS)
|
||||||
public Map<String,String> stripedLockConcurrentHashMap() throws InterruptedException {
|
public Map<String,String> stripedLockConcurrentHashMap() throws InterruptedException {
|
||||||
return stripedLock.doWork(new ConcurrentHashMap<String,String>(), THREADS, SLOTS);
|
return stripedLock.doWork(new ConcurrentHashMap<String,String>(), TASKS, SLOTS);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,10 +7,10 @@ import com.google.common.base.Supplier;
|
||||||
|
|
||||||
public abstract class ConcurrentAccessExperiment {
|
public abstract class ConcurrentAccessExperiment {
|
||||||
|
|
||||||
public final Map<String,String> doWork(Map<String,String> map, int threads, int slots) {
|
public final Map<String,String> doWork(Map<String,String> map, int tasks, int slots) {
|
||||||
CompletableFuture<?>[] requests = new CompletableFuture<?>[threads * slots];
|
CompletableFuture<?>[] requests = new CompletableFuture<?>[tasks * slots];
|
||||||
|
|
||||||
for (int i = 0; i < threads; i++) {
|
for (int i = 0; i < tasks; i++) {
|
||||||
requests[slots * i + 0] = CompletableFuture.supplyAsync(putSupplier(map, i));
|
requests[slots * i + 0] = CompletableFuture.supplyAsync(putSupplier(map, i));
|
||||||
requests[slots * i + 1] = CompletableFuture.supplyAsync(getSupplier(map, i));
|
requests[slots * i + 1] = CompletableFuture.supplyAsync(getSupplier(map, i));
|
||||||
requests[slots * i + 2] = CompletableFuture.supplyAsync(getSupplier(map, i));
|
requests[slots * i + 2] = CompletableFuture.supplyAsync(getSupplier(map, i));
|
||||||
|
|
Loading…
Reference in New Issue