Java 生產者消費者實現

import java.util.concurrent.*;
import java.util.concurrent.atomic.AtomicInteger;

public class ConsumerAndProduct {

    protected static final ThreadPoolExecutor executor = new ThreadPoolExecutor(10,
            100, 2,
            TimeUnit.MINUTES, new LinkedBlockingQueue<Runnable>(),
            new ThreadFactory() {
                public AtomicInteger id = new AtomicInteger(0);

                @Override
                public Thread newThread(Runnable r) {
                    Thread thread = new Thread(r);
                    thread.setName("home-service-" + id.addAndGet(1));
                    return thread;
                }
            }, new ThreadPoolExecutor.CallerRunsPolicy());
    static boolean falg = false;
    static int cur = 1;

    public static void main(String[] args) {
        ConsumerAndProduct consumerAndProduct = new ConsumerAndProduct();
        for (int i = 0; i < 10; i++) {
            executor.submit(new Consumer(consumerAndProduct));
            executor.submit(new Product(consumerAndProduct));
        }
    }

    // 生產者
    static class Consumer implements Runnable {
        private ConsumerAndProduct consumerAndProduct;
        public Consumer(ConsumerAndProduct consumerAndProduct){
            this.consumerAndProduct = consumerAndProduct;
        }
        @Override
        public void run() {
            synchronized (consumerAndProduct) {
                if (falg) {
                    try {
                        this.wait();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
                cur++;
                System.out.println("生產者" + cur);
                falg = true;
                this.notify();
            }
        }
    }

    // 消費者
    static class Product implements Runnable {
        private ConsumerAndProduct consumerAndProduct;
        public Product(ConsumerAndProduct consumerAndProduct){
            this.consumerAndProduct = consumerAndProduct;
        }
        @Override
        public void run() {
            synchronized (consumerAndProduct) {
                if (!falg) {
                    try {
                        this.wait();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
                cur--;
                System.out.println("消費者 " + cur);
                falg = false;
                this.notify();
            }
        }
    }
}

 

結果爲

生產者2
消費者 1
生產者2
消費者 1
生產者2
消費者 1
生產者2
消費者 1
生產者2
消費者 1
生產者2
消費者 1
生產者2
消費者 1

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章