Java生產(chǎn)者消費者模式實例分析
本文實例講述了Java生產(chǎn)者消費者模式。分享給大家供大家參考,具體如下:
java的生產(chǎn)者消費者模式,有三個部分組成,一個是生產(chǎn)者,一個是消費者,一個是緩存。
這么做有什么好處呢?
1.解耦(去依賴),如果是消費者直接調(diào)用生產(chǎn)者,那如果生產(chǎn)者的代碼變動了,消費者的代碼也需要隨之變動
2.高效,如果消費者直接掉生產(chǎn)者,執(zhí)行時間較長的話,會阻塞,影響其他業(yè)務(wù)的進行
3.負(fù)載均衡,如果消費者直接調(diào)生產(chǎn)者,那生產(chǎn)者和消費者就得在一起了,日后業(yè)務(wù)量非常大的話,要想減輕服務(wù)器的壓力,想拆分生產(chǎn)和消費,就很困難
/** * 我是生產(chǎn)者,負(fù)責(zé)生產(chǎn) */ public class Product implements Runnable { private Queue q; public Product(Queue q) { this.q = q; } @Override public void run() { try { for (int i = 0; i < 3; i++) { q.product("test" + i); } } catch (InterruptedException e) { e.printStackTrace(); } } }
/** *我是消費者,負(fù)責(zé)消費 */ public class Consumer implements Runnable { private Queue q; public Consumer(Queue q){ this.q = q; } @Override public void run() { try { for(int i=0 ; i < 3 ; i++){ q.consumer(); } } catch (InterruptedException e) { e.printStackTrace(); } } }
/** * *我是緩存,負(fù)責(zé)產(chǎn)品的存(生產(chǎn)后的放置)取(消費時的獲取) */ public class Queue { private final Object lock = new Object(); private List<String> list = new ArrayList<String>(); public void product(String param) throws InterruptedException { synchronized (lock) { System.out.println("product生產(chǎn)"); list.add(param); lock.notify(); lock.wait(); } } public void consumer() throws InterruptedException { synchronized (lock) { lock.wait(); System.out.println("product消費"); if (list.size() > 0) { list.remove(list.size() - 1); } lock.notify(); } } } public class TestMain { public static void main(String[] args) { Queue q = new Queue(); Product p = new Product(q); Consumer s = new Consumer(q); Thread t1 = new Thread(p); Thread t2 = new Thread(s); t1.start(); t2.start(); } }
更多關(guān)于java算法相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設(shè)計有所幫助。
相關(guān)文章
Java數(shù)據(jù)結(jié)構(gòu)順序表用法詳解
順序表是計算機內(nèi)存中以數(shù)組的形式保存的線性表,線性表的順序存儲是指用一組地址連續(xù)的存儲單元依次存儲線性表中的各個元素、使得線性表中在邏輯結(jié)構(gòu)上相鄰的數(shù)據(jù)元素存儲在相鄰的物理存儲單元中,即通過數(shù)據(jù)元素物理存儲的相鄰關(guān)系來反映數(shù)據(jù)元素之間邏輯上的相鄰關(guān)系2021-10-10解決java.util.HashMap$Values?cannot?be?cast?to?java.ut的問題
這篇文章主要介紹了解決java.util.HashMap$Values?cannot?be?cast?to?java.ut的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03springboot @ConfigurationProperties和@PropertySource的區(qū)別
這篇文章主要介紹了springboot @ConfigurationProperties和@PropertySource的區(qū)別,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06