zoukankan      html  css  js  c++  java
  • 生产者消费者模型的四种java编程例子(转载)

    package producer_customer;  
      
    public class ProducerCustomer1 {  
        public static int limit = 10;  
        public static int have = 0;  
        public static int start = 0;  
        Task[] tasklist = new Task[limit];  
      
        class Producer implements Runnable {  
            @Override  
            public void run() {  
                while (true) {  
                    synchronized (tasklist) {  
                        if (ProducerCustomer1.have < ProducerCustomer1.limit) {  
                            Task temp = new Task(  
                                    "mytest"  
                                            + (ProducerCustomer1.start + ProducerCustomer1.have)  
                                            % ProducerCustomer1.limit+" "+Thread.currentThread().getId());  
                              
                            tasklist[(ProducerCustomer1.start + ProducerCustomer1.have)  
                                    % ProducerCustomer1.limit] = temp;  
                            ProducerCustomer1.have++;  
                            tasklist.notifyAll();  
                        } else {  
                            try {  
                                tasklist.wait();  
                            } catch (InterruptedException e) {  
                                e.printStackTrace();  
                            }  
                        }  
                    }  
                }  
      
            }  
        }  
      
        class Customer implements Runnable {  
            @Override  
            public void run() {  
                while (true) {  
                    Task temp = null;  
                    synchronized (tasklist) {  
                        if (ProducerCustomer1.have > 0) {  
                            temp = tasklist[ProducerCustomer1.start];  
                            ProducerCustomer1.start = (ProducerCustomer1.start + 1)  
                                    % ProducerCustomer1.limit;  
                            ProducerCustomer1.have--;  
                            System.out.println(temp.taskname + ":"  
                                    + Thread.currentThread().getId());  
                            tasklist.notifyAll();  
                        } else {  
                            try {  
                                tasklist.wait();  
                            } catch (InterruptedException e) {  
                                e.printStackTrace();  
                            }  
                        }  
      
                    }  
                }  
            }  
        }  
      
        class Task {  
            public String taskname;  
            public Task(String taskname) {  
                this.taskname = taskname;  
            }  
        }  
        public static void main(String[] args) {  
            ProducerCustomer1 p = new ProducerCustomer1();  
            Producer producer = p.new Producer();  
            Customer customer = p.new Customer();  
            new Thread(producer).start();  
            new Thread(producer).start();  
            new Thread(producer).start();  
            new Thread(producer).start();  
            new Thread(customer).start();  
            new Thread(customer).start();  
            new Thread(customer).start();  
        }  
    }  


    [java] view plaincopy
    package producer_customer;  
      
    import java.util.concurrent.locks.Condition;  
    import java.util.concurrent.locks.Lock;  
    import java.util.concurrent.locks.ReentrantLock;  
      
      
    public class ProducerCustomer2 {  
      
        public static int limit = 10;  
        public static int have = 0;  
        public static int start = 0;  
        Task[] tasklist = new Task[limit];  
        private final Lock lock = new ReentrantLock();  
        private final Condition full = lock.newCondition();  
        private final Condition empty = lock.newCondition();  
      
        class Producer implements Runnable {  
            @Override  
            public void run() {  
                while (true) {  
                    lock.lock();  
                    if (ProducerCustomer2.have < ProducerCustomer2.limit) {  
                        Task temp = new Task(  
                                "mytest"  
                                        + (ProducerCustomer2.start + ProducerCustomer2.have)  
                                        % ProducerCustomer2.limit + " "  
                                        + Thread.currentThread().getId());  
                        tasklist[(ProducerCustomer2.start + ProducerCustomer2.have)  
                                % ProducerCustomer2.limit] = temp;  
                        ProducerCustomer2.have++;  
                        empty.signalAll();  
                    } else {  
                        try {  
                            full.await();  
                        } catch (InterruptedException e) {  
                            e.printStackTrace();  
                        }  
                    }  
                    lock.unlock();  
                }  
      
            }  
      
        }  
      
        class Customer implements Runnable {  
            @Override  
            public void run() {  
                while (true) {  
                    Task temp = null;  
                    lock.lock();  
                    if (ProducerCustomer2.have > 0) {  
                        temp = tasklist[ProducerCustomer2.start];  
                        ProducerCustomer2.start = (ProducerCustomer2.start + 1)  
                                % ProducerCustomer2.limit;  
                        ProducerCustomer2.have--;  
                        System.out.println(temp.taskname + ":"  
                                + Thread.currentThread().getId());  
                        full.signalAll();  
                    } else {  
                        try {  
                            empty.await();  
                        } catch (InterruptedException e) {  
                            e.printStackTrace();  
                        }  
                    }  
                    lock.unlock();  
                }  
            }  
        }  
      
        class Task {  
            public String taskname;  
      
            public Task(String taskname) {  
                this.taskname = taskname;  
            }  
        }  
      
        public static void main(String[] args) {  
            ProducerCustomer2 p = new ProducerCustomer2();  
            Producer producer = p.new Producer();  
            Customer customer = p.new Customer();  
            new Thread(producer).start();  
            new Thread(producer).start();  
            new Thread(producer).start();  
            new Thread(producer).start();  
            new Thread(customer).start();  
            new Thread(customer).start();  
            new Thread(customer).start();  
        }  
    }  


    [java] view plaincopy
    package producer_customer;  
      
    import java.util.concurrent.LinkedBlockingQueue;  
      
    public class ProducerCustomer3 {  
        public static int limit = 10;  
        public static int have = 0;  
        public static int start = 0;  
        LinkedBlockingQueue queue = new LinkedBlockingQueue(limit);  
        class Customer implements Runnable {  
            @Override  
            public void run() {  
                while (true) {  
                    try {  
                        Tasks ss=queue.take();  
                        System.out.println(ss.taskname+":"+Thread.currentThread().getId());  
                    } catch (InterruptedException e) {  
                        e.printStackTrace();  
                    }  
                }  
            }  
        }  
      
        class Producer implements Runnable {  
            @Override  
            public void run() {  
                while (true) {  
                    Tasks o = new Tasks("test"+Thread.currentThread().getId());  
                     try {  
                        queue.put(o);  
                    } catch (InterruptedException e) {  
                        e.printStackTrace();  
                    }  
                      
                }  
            }  
        }  
      
        class Tasks {  
            public String taskname;  
      
            public Tasks(String taskname) {  
                this.taskname = taskname;  
            }  
        }  
        public static void main(String[] args) {  
            ProducerCustomer3 p = new ProducerCustomer3();  
            Producer producer = p.new Producer();  
            Customer customer = p.new Customer();  
            new Thread(producer).start();  
            new Thread(producer).start();  
            new Thread(producer).start();  
            new Thread(producer).start();  
            new Thread(customer).start();  
            new Thread(customer).start();  
            new Thread(customer).start();  
        }  
    }  



    [java] view plaincopy
    package producer_customer;  
      
    import java.util.concurrent.Semaphore;  
      
    public class ProducerCustomer4 {  
        Semaphore mutex = new Semaphore(1);// 互斥量  
        Semaphore notfull = new Semaphore(10);  
        Semaphore notempty = new Semaphore(0);  
        String[] array = new String[10];  
        int putptr, takeptr, count = 0;  
      
        class Producer implements Runnable {  
            @Override  
            public void run() {  
                while (true) {  
                    try {  
                        notfull.acquire();  
                        mutex.acquire();  
                        if (putptr == array.length)  
                            putptr = 0;  
                        String temp = new String("temp" + ":" + putptr + ":"  
                                + Thread.currentThread().getId());  
                        array[putptr] = temp;  
                        putptr++;  
                        count++;  
                        mutex.release();  
                        notempty.release();  
                    } catch (InterruptedException e) {  
                        e.printStackTrace();  
                    }  
                }  
            }  
        }  
      
        class Consumer implements Runnable {  
            @Override  
            public void run() {  
                while (true) {  
                    try {  
                        notempty.acquire();  
                        mutex.acquire();  
                        if (takeptr == array.length)  
                            takeptr = 0;  
                        System.out.println(array[takeptr] + ":" + takeptr + ":"  
                                + Thread.currentThread().getId());  
                        takeptr++;  
                        count--;  
                        mutex.release();  
                        notfull.release();  
                    } catch (InterruptedException e) {  
                        e.printStackTrace();  
                    }  
                }  
            }  
        }  
      
        public static void main(String[] args) {  
            ProducerCustomer4 s = new ProducerCustomer4();  
            Producer producer = s.new Producer();  
            Consumer consumer = s.new Consumer();  
            new Thread(producer).start();  
            new Thread(producer).start();  
            new Thread(producer).start();  
            new Thread(consumer).start();  
            new Thread(consumer).start();  
        }  
    }  

  • 相关阅读:
    AppDomain and related
    实现 Finalize 和 Dispose 以清理非托管资源
    递归显示treeview,求更好方法
    SQL练习题之子查询
    jquery in action 学习笔记
    daily english 201117
    TOP AND APPLY
    Create trace with tsql
    (转)sqlserver 锁查看
    一个简单的windows services demo(c#)
  • 原文地址:https://www.cnblogs.com/younghome/p/4608980.html
Copyright © 2011-2022 走看看