/**
* 循环次数
*/
private volatile static int loopNum = 5000;
/**
* volatile 保证内存可见性
*/
private volatile static int currentValue = 1;
/**
* Join 可以保证线程顺序执行,可以通过 Join 的方式串行执行
* 创建 5000 个线程,每个线程需要等待前一个线程执行完成,从而实现串行执行
*
* 思考:这里是采用直接创建循环次数的线程数,可以优化为只维护两个线程的方式,即首节点线程执行完成后创建新线程执行
*/
private static void cyclePrintUseJoin() {
Thread preThread = null;
for (int i = 0; i < loopNum; i++) {
preThread = new Thread(new JoinTask(preThread));
preThread.start();
}
}
static class JoinTask implements Runnable {
private final Thread preThread;
public JoinTask(Thread thread) {
this.preThread = thread;
}
@Override
public void run() {
// 如果 preThread 不为空表示不是头节点线程需要等待 preThread 执行完成
if (preThread != null) {
try {
preThread.join();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
System.out.println(currentValue);
if (currentValue == 3) {
currentValue = 1;
} else {
currentValue++;
}
}
}
/**
* 循环次数
*/
private volatile static int loopNum = 5000;
/**
* volatile 保证内存可见性
*/
private volatile static int currentValue = 1;
private static final Object lockObj = new Object();
/**
* 使用 synchronized 串行执行代码块
*/
private static void cyclePrintUseSynchronized() {
new Thread(new SynchronizedTask()).start();
new Thread(new SynchronizedTask()).start();
new Thread(new SynchronizedTask()).start();
}
static class SynchronizedTask implements Runnable {
@Override
public void run() {
while (true) {
synchronized (Test1.class) {
if (loopNum < 0) {
return;
}
System.out.println(currentValue);
if (currentValue == 3) {
currentValue = 1;
} else {
currentValue++;
}
loopNum--;
}
}
}
}
/**
* 循环次数
*/
private static int loopNum = 5000;
/**
* 当前打印数字
*/
private static int currentValue = 1;
private static final Object lockObj = new Object();
/**
* 使用 synchronized 串行执行代码块
* 且对应线程只处理对应任务
*/
private static void cyclePrintUseSynchronizedPlus() {
new Thread(new SynchronizedTaskPlus(1)).start();
new Thread(new SynchronizedTaskPlus(2)).start();
new Thread(new SynchronizedTaskPlus(3)).start();
}
static class SynchronizedTaskPlus implements Runnable {
private final int target;
public SynchronizedTaskPlus(int target) {
this.target = target;
}
@Override
public void run() {
while (true) {
synchronized (lockObj) {
if (loopNum < 0) {
return;
}
if (currentValue != target) {
try {
// 这里为了避免过多的无效抢占锁,使当前线程 进入等待状态(获取到锁但打印的数字和线程的绑定的数字不一样)
lockObj.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
System.out.println(currentValue);
if (currentValue == 3) {
currentValue = 1;
} else {
currentValue++;
}
loopNum--;
// 注:这里需要唤醒所有的线程,因为唤醒的线程可能不是目标线程,导致无效唤醒
lockObj.notifyAll();
}
}
}
}
/**
* 循环次数
*/
private volatile static int loopNum = 5000;
/**
* volatile 保证内存可见性
*/
private volatile static int currentValue = 1;
private static final ReentrantLock reentrantLock = new ReentrantLock();
/**
* 使用 ReentrantLock 串行执行代码块
*/
private static void cyclePrintUseReentrantLock() {
new Thread(new ReentrantLockTask()).start();
new Thread(new ReentrantLockTask()).start();
new Thread(new ReentrantLockTask()).start();
}
static class ReentrantLockTask implements Runnable {
@Override
public void run() {
while (true) {
reentrantLock.lock();
try {
if (loopNum < 0) {
return;
}
System.out.println(currentValue);
if (currentValue == 3) {
currentValue = 1;
} else {
currentValue++;
}
loopNum--;
} finally {
reentrantLock.unlock();
}
}
}
}
阅读量:2016
点赞量:0
收藏量:0