-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCyclicBarrierTest.java
More file actions
67 lines (60 loc) · 1.97 KB
/
CyclicBarrierTest.java
File metadata and controls
67 lines (60 loc) · 1.97 KB
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
package Thread.concurrent;
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
/*
* CycliBarrier用法:
* 模拟所有写操作完成才能进行下面的操作
*
* */
public class CyclicBarrierTest {
private static int count=4;
public static void main(String[] args) {
CyclicBarrier cyclicBarrier=new CyclicBarrier(count, new Runnable() {
@Override
public void run() {
//这里从四个线程中随机抽取一个线程来完成
System.out.println("所有线程的写入操作已经完成,当前线程是:"+Thread.currentThread().getName());
}
});
ExecutorService service=Executors.newCachedThreadPool();
for(int i=0;i<count;i++)
service.execute(new Writer(cyclicBarrier));
try {
//阻塞住main线程,让其他线程执行
TimeUnit.MICROSECONDS.sleep(4000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//CyclicBarrier重用
System.out.println("重用CylicBarrer-------");
for(int i=0;i<count;i++)
service.execute(new Writer(cyclicBarrier));
}
}
class Writer implements Runnable{
public CyclicBarrier cyclicBarrier;
public Writer(CyclicBarrier cyclicBarrier){
this.cyclicBarrier=cyclicBarrier;
}
@Override
public void run() {
try {
System.out.println(Thread.currentThread().getName()+"写操作开始");
//sleep模拟写操作
TimeUnit.MICROSECONDS.sleep(1000);
System.out.println(Thread.currentThread().getName()+"写操作结束,等待其他线程写操作结束...");
cyclicBarrier.await();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (BrokenBarrierException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+"线程的写入操作完成");
}
}