1.lock锁的模式
package con.carry.并发.生产者消费者模型;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
/**
* 实现线程交替加一和减一操作,循环十次
*/
public class ReetLockDemo {
public static void main(String[] args) {
ShareData shareData = new ShareData();
new Thread(() -> {
for (int i = 0; i < 10; i++) {
shareData.increment();
}
}, "A").start();
new Thread(() -> {
for (int i = 0; i < 10; i++) {
shareData.decrement();
}
}, "B").start();
}
}
class ShareData {
private int num = 0;
private Lock lock = new ReentrantLock();
private Condition condition = lock.newCondition();
public void increment() {
lock.lock();
try {
//判断!
while (num != 0) {
condition.await();
}
//干活
num++;
System.out.println(Thread.currentThread().getName() + ":" + num);
// 通知
condition.signalAll();
} catch (Exception e) {
e.printStackTrace();
} finally {
lock.unlock();
}
}
public void decrement() {
lock.lock();
try {
//判断!
while (num == 0) {
condition.await();
}
//干活
num--;
System.out.println(Thread.currentThread().getName() + ":" + num);
// 通知
condition.signalAll();
} catch (Exception e) {
e.printStackTrace();
} finally {
lock.unlock();
}
}
}
2.阻塞队列的模式
本文通过示例代码展示了如何使用ReentrantLock和Condition实现线程间的交替执行,具体为两个线程分别进行加一和减一操作,确保了线程的安全性和有序性。此模式适用于需要精确控制线程执行顺序的场景。
631

被折叠的 条评论
为什么被折叠?



