zoukankan      html  css  js  c++  java
  • 多线程的多消费者和多生产者signal和await

    package test;
    
    import java.awt.List;
    import java.awt.image.AreaAveragingScaleFilter;
    import java.lang.reflect.Array;
    import java.math.BigDecimal;
    import java.math.BigInteger;
    import java.util.*;
    import java.util.concurrent.CountDownLatch;
    import java.util.concurrent.locks.Condition;
    import java.util.concurrent.locks.Lock;
    import java.util.concurrent.locks.ReentrantLock;
    import java.io.BufferedInputStream;
    import java.io.OutputStreamWriter;
    import java.io.PrintWriter;
    import java.io.Reader;
    import java.io.Writer;
    import javax.security.auth.callback.LanguageCallback;
    import javax.swing.text.StyledEditorKit.BoldAction;
    
    class Resourse {
    	private String name;
    	private boolean flag = false;
    	private int count;
    	Lock lock = new ReentrantLock();
    	Condition proCondition = lock.newCondition();
    	Condition condition = lock.newCondition();
    
    	public void put(String name) {
    		lock.lock();
    		try {
    			while (flag) {
    				try {
    					proCondition.await();
    				} catch (InterruptedException e) {
    					e.printStackTrace();
    				}
    			}
    
    			flag = true;
    			++count;
    			this.name = name + count;
    			condition.signal();
    		} finally {
    			lock.unlock();
    		}
    	}
    
    	public void take() {
    		lock.lock();
    		try {
    			while (!flag) {
    				try {
    					condition.await();
    				} catch (InterruptedException e) {
    					e.printStackTrace();
    				}
    			}
    			flag = false;
    			System.out.println(Thread.currentThread().getName() + " ........" + this.name);
    			proCondition.signal();
    		} finally {
    			lock.unlock();
    		}
    	}
    }
    
    class Producer implements Runnable {
    	Resourse r;
    
    	Producer(Resourse r) {
    		this.r = r;
    	}
    
    	@Override
    	public void run() {
    		while (true) {
    			r.put("烤鸭");
    		}
    	}
    
    }
    
    class Consumer implements Runnable {
    	Resourse r;
    
    	Consumer(Resourse r) {
    		this.r = r;
    	}
    
    	@Override
    	public void run() {
    		while (true)
    			r.take();
    	}
    
    }
    
    public class Main {
    
    	public static void main(String[] args) throws Exception {
    
    		Scanner scanner = new Scanner(new BufferedInputStream(System.in));
    		PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));
    		
    		Resourse r = new Resourse();
    		Producer a = new Producer(r);
    		Producer b = new Producer(r);
    		Consumer c = new Consumer(r);
    		Consumer d = new Consumer(r);
    		
    		Thread t1 = new Thread(a);
    		Thread t2 = new Thread(b);
    		Thread t3 = new Thread(c);
    		Thread t4 = new Thread(d);
    		
    		t1.start();
    		t2.start();
    		t3.start();
    		t4.start();
    	}
    }
    

      

  • 相关阅读:
    http 协议相关问题
    网卡中断及多队列
    Visual Studio Code 配置C/C++环境
    C++通用框架和库
    命令行的艺术
    NetScaler Logs Collection Guide
    C++性能榨汁机之无锁编程
    Codeforces 839E Mother of Dragons【__builtin_popcount()的使用】
    C/C++中__builtin_popcount()的使用及原理
    Codeforces 839D Winter is here【数学:容斥原理】
  • 原文地址:https://www.cnblogs.com/WINDZLY/p/11788632.html
Copyright © 2011-2022 走看看