线程安全10_阻塞式线程安全队列

package com.bao.demo;

import java.util.ArrayList;
import java.util.List;

/**
 * 使用synchronized、wait、notify实现带阻塞的线程安全队列
 */
class MQueue {

    private List<String> list = new ArrayList<String>();

    private int maxSize;

    private Object lock = new Object();

    public MQueue(int maxSize){
        this.maxSize=maxSize;
        System.out.println("线程"+Thread.currentThread().getName()+"已初始化长度为"+this.maxSize+"的队列");
    }

    public void put(String element){
        synchronized (lock) {
            if(this.list.size()==this.maxSize){
                try {
                    System.out.println("线程"+Thread.currentThread().getName()+"当前队列已满put等待...");
                    lock.wait();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
            this.list.add(element);
            System.out.println("线程"+Thread.currentThread().getName()+"向队列中加入元素:"+element);
            lock.notifyAll(); //通知可以取数据
        }
    }

    public String take(){
        synchronized (lock) {
            if(this.list.size()==0){
                try {
                    System.out.println("线程"+Thread.currentThread().getName()+"队列为空take等待...");
                    lock.wait();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
            String result = list.get(0);
            list.remove(0);
            System.out.println("线程"+Thread.currentThread().getName()+"获取数据:"+result);
            lock.notifyAll(); //通知可以加入数据
            return result;
        }
    }
}

public class DemoThread20 {
    public static void main(String[] args) {
        final MQueue q = new MQueue(5);

        new Thread(new Runnable() {
            public void run() {
                q.put("1");
                q.put("2");
                q.put("3");
                q.put("4");
                q.put("5");
                q.put("6");
            }
        },"t1").start();

        new Thread(new Runnable() {
            public void run() {
                q.put("11");
                q.put("21");
                q.put("31");
                q.put("41");
                q.put("51");
                q.put("61");
            }
        },"t2").start();

        new Thread(new Runnable() {
            public void run() {
                q.take();
                q.take();
                q.take();
                q.take();
                q.take();
            }
        },"t3").start();

        new Thread(new Runnable() {
            public void run() {
                q.take();
                q.take();
                q.take();
                q.take();
                q.take();
            }
        },"t4").start();
    }
}

输出结果是随机的,但是在put和task之间不会出现死锁,是一个阻塞式线程安全队列。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值