一文詳解Java閉鎖和柵欄的實現
題目描述 -閉鎖
題目
有3個線程,線程A和線程B並行執行,線程C需要和線程A和B執行完成後才能執行,使用閉鎖CountDownLatch實現
解題思路
創建一個類 :Abc Test
CountDownLatch初始化值為2
新增 A B線程,在線程裡執行邏輯後,計算-1
countDownLatch.countDown()
新增C線程,等待A,B線程來完成
countDownLatch.await();
執行相關的邏輯
代碼詳解
AbcTest:
package cn.xiaoxuzhu.daily; import java.util.concurrent.CountDownLatch; public class AbcTest { public static void main(String[] args) { CountDownLatch countDownLatch =new CountDownLatch(2); //線程A new Thread(new Runnable() { @Override public void run() { try { Thread.sleep(2000); }catch (InterruptedException e){ e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"線程A執行結束"); countDownLatch.countDown(); } },"線程A").start(); //線程B new Thread(new Runnable() { @Override public void run() { try { Thread.sleep(1000); }catch (InterruptedException e){ e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"線程B執行結束"); countDownLatch.countDown(); } },"線程B").start(); new Thread(new Runnable() { @Override public void run() { try { countDownLatch.await(); }catch (InterruptedException e){ e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"線程C執行結束"); countDownLatch.countDown(); } },"線程C").start(); } }
題目二描述 :柵欄
題目
有3個線程,線程A和線程B並發執行,線程C需要A和B執行完成後才能執行。使用刪欄CyclicBarrier實現
解題思路
柵欄類似於閉鎖,它能阻塞一組線程直到某個事件發生。柵欄與閉鎖的關鍵區別在於,所有的線程
必須同時到達柵欄的位置,才能繼續執行。
創建一個類:Abc Test2
CyclicBarrier初始化值為3
新增A,B線程,在線程裡執行完邏輯後,柵欄等待,符合三個線程都達到柵欄才往下執行
cyclicBarrier.wait();
新增C線程,先柵欄等待,等A,B線程到達柵欄,就一起往下執行
代碼詳解
package cn.xiaoxuzhu.daily; import java.util.concurrent.BrokenBarrierException; import java.util.concurrent.CyclicBarrier; /** * Description: 有3個線程。線程A和線程B並行執行,線程C需要A和B執行完成後才能執行。可以怎麼實現? * * @author 小王同學 * @version 1.0 * @Description: */ public class AbcTest2 { public static void main(String[] args) { CyclicBarrier cyclicBarrier=new CyclicBarrier(3); //線程A new Thread(new Runnable() { @Override public void run() { try { Thread.sleep(2000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"線程A執行結束"); try { cyclicBarrier.await();//符合三個線程都到達柵欄才往下執行 } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } },"線程A").start(); //線程B new Thread(new Runnable() { @Override public void run() { try { Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"線程B執行結束"); try { cyclicBarrier.await();//符合三個線程都到達柵欄才往下執行 } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } } },"線程B").start(); //線程C new Thread(new Runnable() { @Override public void run() { //等待A,B線程完成 try { cyclicBarrier.await();//符合三個線程都到達柵欄才往下執行 } catch (InterruptedException e) { e.printStackTrace(); } catch (BrokenBarrierException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+":"+"線程C執行結束"); } },"線程C").start(); } }
到此這篇關於一文詳解Java閉鎖和柵欄的實現的文章就介紹到這瞭,更多相關Java閉鎖 柵欄內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Java中CyclicBarrier 循環屏障
- Java中CyclicBarrier和CountDownLatch的用法與區別
- java並發包中CountDownLatch和線程池的使用詳解
- java多線程CyclicBarrier的使用案例,讓線程起步走
- Java並發編程之詳解CyclicBarrier線程同步