/
ThreadBasedCounter.java
49 lines (41 loc) · 1.2 KB
/
ThreadBasedCounter.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
package counter;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.concurrent.atomic.AtomicIntegerArray;
public class ThreadBasedCounter implements Counter {
private AtomicIntegerArray atomicArray;
private AtomicInteger base = new AtomicInteger();
private int mode;
public ThreadBasedCounter(int size) {
int newSize = 1;
while (newSize < size) {
newSize = newSize << 1;
}
atomicArray = new AtomicIntegerArray(newSize);
mode = newSize - 1;
}
@Override
public int inc() {
int id = (int) Thread.currentThread().getId();
int index = id & mode;
int fail = 0;
while (true) {
int currVal = atomicArray.get(index);
if (atomicArray.compareAndSet(index, currVal, currVal + 1))
break;
fail++;
currVal = base.get();
if (base.compareAndSet(currVal, currVal + 1))
break;
fail++;
}
return fail;
}
@Override
public int get() {
int sum = base.get();
for (int i = 0; i < mode + 1; i++) {
sum += atomicArray.get(i);
}
return sum;
}
}