精确通知,顺序访问——Lock锁比synchronized锁的优势之处
生活随笔
收集整理的這篇文章主要介紹了
精确通知,顺序访问——Lock锁比synchronized锁的优势之处
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
題目如下:
多線程之間按順序調(diào)用,實(shí)現(xiàn)A-》B-》C
三個(gè)線程啟動(dòng),要求如下:
AA 打印5次,BB 打印10次,CC 打印15次
接著
? AA 打印5次,BB 打印10次,CC 打印15次
......來10輪
package com.dym.juc;import java.util.concurrent.locks.Condition; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock;class ShareResource{private int number=1; //1:A 2:B 3:Cprivate Lock lock=new ReentrantLock();private Condition condition1=lock.newCondition();private Condition condition2=lock.newCondition();private Condition condition3=lock.newCondition();public void print5(){lock.lock();try {//1. 判斷while (number!=1){condition1.await();}//2. 干活for (int i = 1; i <=5 ; i++) {System.out.println(Thread.currentThread().getName()+"\t"+i);}//3. 通知number=2;condition2.signal();} catch (InterruptedException e) {e.printStackTrace();} finally {lock.unlock();}}public void print10(){lock.lock();try {//1. 判斷while (number!=2){condition2.await();}//2. 干活for (int i = 1; i <=10 ; i++) {System.out.println(Thread.currentThread().getName()+"\t"+i);}//3. 通知number=3;condition3.signal();} catch (InterruptedException e) {e.printStackTrace();} finally {lock.unlock();}}public void print15(){lock.lock();try {//1. 判斷while (number!=3){condition3.await();}//2. 干活for (int i = 1; i <=15 ; i++) {System.out.println(Thread.currentThread().getName()+"\t"+i);}//3. 通知number=1;condition1.signal();} catch (InterruptedException e) {e.printStackTrace();} finally {lock.unlock();}} }// 多線程之間按順序調(diào)用,實(shí)現(xiàn)A-》B-》C // 三個(gè)線程啟動(dòng),要求如下: // AA 打印5次,BB 打印10次,CC 打印15次 // 接著 // AA 打印5次,BB 打印10次,CC 打印15次 // ......來10輪 /*1 高內(nèi)聚低耦合的前提下,線程操作資源類2 判斷/干活/通知3 多線程交互中,必須要防止多線程的虛假喚醒,也即(判斷只用while,不能用if)4 標(biāo)志位 */public class ThreadOrderAccess {public static void main(String[] args) {ShareResource shareResource=new ShareResource();new Thread(()->{for (int i = 1; i <=10 ; i++) {shareResource.print5();}},"AA").start();new Thread(()->{for (int i = 1; i <=10 ; i++) {shareResource.print10();}},"BB").start();new Thread(()->{for (int i = 1; i <=10 ; i++) {shareResource.print15();}},"CC").start();} }
?
總結(jié)
以上是生活随笔為你收集整理的精确通知,顺序访问——Lock锁比synchronized锁的优势之处的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 线程间定制化调用通信—— 1 高内聚低
- 下一篇: JUC里面的相关分类|| java并发