轉載請標明博客的地址java
本人博客和github帳號,若是對你有幫助請在本人github項目AioSocket上點個star,激勵做者對社區貢獻git
看到就是賺到,本博客只會貼出乾貨,歡迎光顧github
本篇講的是lock.condition()的正確使用方式(也是以前看過的一篇,今天又把他實現出來)ide
首先,代碼邏輯規則以下:oop
1.使用3個線程依次打印ABCui
直接上代碼:this
package Thread;線程
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
/**
*
* @ClassName: LockConditionTest
* @Description:三個線程依次打印ABC
* @author:
* @date: 2019年6月27日 下午4:31:41
* @version 1.8.0
* @param
*
*/
public class LockConditionTest{
public static void main(String[] args) {
final AlternateDemo ad = new AlternateDemo();
new Thread(new Runnable() {
@Override
public void run() {
for (int i = 0; i < 10; i++) {
ad.loopA();
}
}
}, "A").start();
new Thread(new Runnable() {
@Override
public void run() {
for (int i = 0; i < 10; i++) {
ad.loopB();
}
}
}, "B").start();
new Thread(new Runnable() {
@Override
public void run() {
for (int i = 0; i < 10; i++) {
ad.loopC();
System.out.println("-----------------------------------");
}
}
}, "C").start();
}
}
class AlternateDemo {
private int number = 1; //當前正在執行線程的標記,至關於狀態標記
private Lock lock = new ReentrantLock();
private Condition condition1 = lock.newCondition();
private Condition condition2 = lock.newCondition();
private Condition condition3 = lock.newCondition();
public void loopA() {
lock.lock();
try {
//1. 判斷
if (number != 1) {
condition1.await();
}
//2. 打印
System.out.println(Thread.currentThread().getName());
//3. 喚醒
number = 2;
condition2.signal();
} catch (Exception e) {
e.printStackTrace();
} finally {
lock.unlock();
}
}
public void loopB() {
lock.lock();
try {
//1. 判斷
if (number != 2) {
condition2.await();
}
//2. 打印
System.out.println(Thread.currentThread().getName());
//3. 喚醒
number = 3;
condition3.signal();
} catch (Exception e) {
e.printStackTrace();
} finally {
lock.unlock();
}
}
public void loopC() {
lock.lock();
try {
//1. 判斷
if (number != 3) {
condition3.await();
}
//2. 打印
System.out.println(Thread.currentThread().getName());
//3. 喚醒
number = 1;
condition1.signal();
} catch (Exception e) {
e.printStackTrace();
} finally {
lock.unlock();
}
}
}對象
總結:1.與wait對比,wait方式須要依賴synchronized代碼塊,而condtion.wait()依賴Lock對象,而且代碼更加靈活blog
2.condition.wait()能夠將不一樣條件下的線程放入不一樣的等待隊列,而單純的wait()方法會將全部狀況下的線程放入一個等待隊列,這樣在大量線程喚醒時會形成資源浪費
3.使用Lock對象進行同步,這樣線程同步只須要依賴Lock對象,而使用原始的synchronized(this){}進行同步,須要依賴當前對象,筆者更喜歡Lock同步的方式