java 测试排序_java 指令重排序测试

/*** 指令重排序测试

*

*@authorzhangxz

* @date 2019-11-17 16:40*/

public classCmdReorderTest {private static int a = 0;private static int b = 0;private static int c = 0;private static int d = 0;private static int e = 0;private static int f = 0;private static int g = 0;private static int h = 0;/*private static volatile int a = 0;

private static volatile int b = 0;

private static volatile int c = 0;

private static volatile int d = 0;

private static volatile int e = 0;

private static volatile int f = 0;

private static volatile int g = 0;

private static volatile int h = 0;*/

private static ReentrantLock lock = newReentrantLock();public static void main(String[] args) throwsInterruptedException {for (int i = 0; i < 500000; i++) {//join可以保证线程a b都执行完成之后,再继续下一次循环

ThreadA threadA = newThreadA();

threadA.start();

ThreadB threadB= newThreadB();

threadB.start();

threadA.join();

threadB.join();//清空数据,便于测试

a = 0;

b= 0;

c= 0;

d= 0;

e= 0;

f= 0;

g= 0;

h= 0;

}

}static class ThreadA extendsThread {

@Overridepublic voidrun() {

lock.lock();try{

a= 1;

b= 1;

c= 1;

d= 1;

e= 1;

f= 1;

g= 1;

h= 1;

}finally{

lock.unlock();

}

}

}static class ThreadB extendsThread {

@Overridepublic voidrun() {

lock.lock();try{if (b == 1 && a == 0) {

System.out.println("b=1");

}if (c == 1 && (a == 0 || b == 0)) {

System.out.println("c=1");

}if (d == 1 && (a == 0 || b == 0 || c == 0)) {

System.out.println("d=1");

}if (e == 1 && (a == 0 || b == 0 || c == 0 || d == 0)) {

System.out.println("e=1");

}if (f == 1 && (a == 0 || b == 0 || c == 0 || d == 0 || e == 0)) {

System.out.println("f=1");

}if (g == 1 && (a == 0 || b == 0 || c == 0 || d == 0 || e == 0 || f == 0)) {

System.out.println("g=1");

}if (h == 1 && (a == 0 || b == 0 || c == 0 || d == 0 || e == 0 || f == 0 || g == 0)) {

System.out.println("h=1");

}

}finally{

lock.unlock();

}

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值