Java Lock鎖多線程中實(shí)現(xiàn)流水線任務(wù)
下面程序代碼通過使用Lock鎖執(zhí)行簡(jiǎn)單的流水線任務(wù):
import java.util.concurrent.locks.Condition;import java.util.concurrent.locks.Lock;import java.util.concurrent.locks.ReentrantLock;/** * @author lzq * @data 2020/4/29 0029 - 下午 9:48 */public class TestLock { public static void main(String[] args) { DataSource dataSource=new DataSource(); new Thread(() -> { for (int i=0;i<10;i++){dataSource.a(); } },'A').start(); new Thread(() -> { for (int i=0;i<10;i++){dataSource.b(); } },'B').start(); new Thread(() -> { for (int i=0;i<10;i++){dataSource.c(); } },'C').start(); }}class DataSource{ private int x=1; private Lock lock=new ReentrantLock(); private Condition condition1=lock.newCondition(); private Condition condition2=lock.newCondition(); private Condition condition3=lock.newCondition(); public void a(){ lock.lock(); try { while(x!=1){condition1.await(); } System.out.println(Thread.currentThread().getName()+':aaa'); x=2; condition2.signal(); } catch (InterruptedException e) { e.printStackTrace(); } finally { lock.unlock(); } } public void b(){ lock.lock(); try { while(x!=2){condition2.await(); } System.out.println(Thread.currentThread().getName()+':bbb'); x=3; condition3.signal(); } catch (InterruptedException e) { e.printStackTrace(); } finally { lock.unlock(); } } public void c(){ lock.lock(); try { while(x!=3){condition3.await(); } System.out.println(Thread.currentThread().getName()+':ccc'); x=1; condition1.signal(); } catch (InterruptedException e) { e.printStackTrace(); } finally { lock.unlock(); } }}
執(zhí)行結(jié)果如下:
對(duì)于上面代碼簡(jiǎn)單分析:代碼中包含簡(jiǎn)單的生產(chǎn)者消費(fèi)者流程和Lock實(shí)現(xiàn)三部曲,即重復(fù)判斷條件,執(zhí)行邏輯,喚醒其他線程和產(chǎn)生鎖,加鎖,解鎖。注意這里一點(diǎn),條件判斷一定要重復(fù)判斷,不然可能會(huì)導(dǎo)致線程假醒影響結(jié)果。
因?yàn)楫?dāng)線程處于等待狀態(tài)時(shí),線程會(huì)釋放資源,等到被喚醒的時(shí)候,從上次await的地方醒來繼續(xù)執(zhí)行,這時(shí)條件判斷成立,執(zhí)行await,其他線程再修改條件使得本線程被喚醒,此時(shí)本線程不會(huì)繼續(xù)判斷,而是繼續(xù)執(zhí)行,如果使用循環(huán)判斷就能檢驗(yàn)出條件被修改。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 爬取今日頭條Ajax請(qǐng)求2. laravel ajax curd 搜索登錄判斷功能的實(shí)現(xiàn)3. JavaScrip簡(jiǎn)單數(shù)據(jù)類型隱式轉(zhuǎn)換的實(shí)現(xiàn)4. HTML DOM setInterval和clearInterval方法案例詳解5. 詳解JSP 內(nèi)置對(duì)象request常見用法6. ASP.NET Core按用戶等級(jí)授權(quán)的方法7. webpack高級(jí)配置與優(yōu)化詳解8. HTML <!DOCTYPE> 標(biāo)簽9. ASP動(dòng)態(tài)網(wǎng)頁(yè)制作技術(shù)經(jīng)驗(yàn)分享10. JS中map和parseInt的用法詳解
