java多线程:15、阻塞队列【BlockingQueue】

来源:互联网 发布:win7 数据恢复 编辑:程序博客网 时间:2024/06/06 02:43

当队列为空时取数据的线程堵塞,当队列满时放数据的新车堵塞

import java.util.Random;import java.util.concurrent.ArrayBlockingQueue;import java.util.concurrent.BlockingQueue;import java.util.concurrent.Exchanger;/** *阻塞队列 */public class ThreadTest2 {    public static void main(String[] args) {        final BlockingQueue<Integer> bq=new ArrayBlockingQueue<>(3);        for(int i=0;i<2;i++){            //放数据线程            new Thread(new Runnable(){                @Override                public void run() {                    while(true){                        int data=new Random().nextInt(5);                        try {                            //当队列满时线程堵塞                            Thread.sleep(data);                            System.out.println(Thread.currentThread().getName()+"开始放数据");                            bq.put(data);                            System.out.println(Thread.currentThread().getName()+"放完数据");                        } catch (InterruptedException e) {                            // TODO Auto-generated catch block                            e.printStackTrace();                        }                    }                }            }).start();        }        //取数据线程         new Thread(new Runnable(){            @Override            public void run() {                while(true){                    try {                        Thread.sleep(new Random().nextInt(5)*1000);                        System.out.println(Thread.currentThread().getName()+"开始取数据");                        //当队列为空时线程阻塞                        int data=bq.take();                        System.out.println(Thread.currentThread().getName()+"取到数据:"+data);                    } catch (InterruptedException e) {                        // TODO Auto-generated catch block                        e.printStackTrace();                    }                }            }        }).start();    }}
0 0
原创粉丝点击