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

本文介绍了一个关于指令重排序的测试案例,通过两个并发线程ThreadA和ThreadB操作共享变量来观察指令重排序的影响。测试中使用了ReentrantLock确保线程安全。

/*** 指令重排序测试

*

*@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();

}

}

}

}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值