package com.ssy.base;
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
public class CountJIAJIATest {
public static void main(String[] args) throws InterruptedException, BrokenBarrierException {
for(int i=0;i<1000;i++){// 执行1000次,其中会有几次不符合预期
new CountTest().run();
}
}
}
/**
* @Author saintshi
* @Date 2016年2月1日 下午4:46:47
* 注:其中CyclicBarrier的作用是等到所有线程都执行完成之后再执行下一步
* 在这里的作用是,主线程等待子线程执行完在执行下一步(count.get())
*/
class CountTest{
final Count count = new Count();
final int _num_thread = 100;
final int _num_count = 1000;
final CyclicBarrier cb = new CyclicBarrier(_num_thread+1);
public void run(){
try {
for(int i=0;i<_num_thread;i++){
Thread t = new Thread(){
public void run() {
try {
for(int j=0;j<_num_count;j++){
count.add();
}
cb.await();
} catch (Exception e) {
e.printStackTrace();
}
};
};
t.setDaemon(false);
t.start();
}
cb.await();
int result = count.get();
if(result!=_num_thread*_num_count){
System.out.println(result);// 如果不符合预期(count++原子执行)就会打印
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
class Count{
private int count;
public void add(){
// synchronized (this) {// 如果不加上会出现与不符合预期的结果
count++;
// }
}
public int get(){
return count;
}
}
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
public class CountJIAJIATest {
public static void main(String[] args) throws InterruptedException, BrokenBarrierException {
for(int i=0;i<1000;i++){// 执行1000次,其中会有几次不符合预期
new CountTest().run();
}
}
}
/**
* @Author saintshi
* @Date 2016年2月1日 下午4:46:47
* 注:其中CyclicBarrier的作用是等到所有线程都执行完成之后再执行下一步
* 在这里的作用是,主线程等待子线程执行完在执行下一步(count.get())
*/
class CountTest{
final Count count = new Count();
final int _num_thread = 100;
final int _num_count = 1000;
final CyclicBarrier cb = new CyclicBarrier(_num_thread+1);
public void run(){
try {
for(int i=0;i<_num_thread;i++){
Thread t = new Thread(){
public void run() {
try {
for(int j=0;j<_num_count;j++){
count.add();
}
cb.await();
} catch (Exception e) {
e.printStackTrace();
}
};
};
t.setDaemon(false);
t.start();
}
cb.await();
int result = count.get();
if(result!=_num_thread*_num_count){
System.out.println(result);// 如果不符合预期(count++原子执行)就会打印
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
class Count{
private int count;
public void add(){
// synchronized (this) {// 如果不加上会出现与不符合预期的结果
count++;
// }
}
public int get(){
return count;
}
}