1.4 wait/notify 实现线程安全的阻塞队列

本文介绍了一个自定义的阻塞队列实现,该队列能够支持多线程并发读写操作,并通过同步机制确保线程安全。当队列满时,写入线程将被阻塞;当队列空时,读取线程将被阻塞,直到有新的数据被写入。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

要解决2个问题:

1.多个线程并发从队列取数据,写数据,要保证同步

2.单个线程取数据,数据为空,阻塞;单个线程写数据,数据满了,阻塞


package com.caolh.base;

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


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() {
			@Override
			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() {
			@Override
			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() {
			@Override
			public void run() {
				q.take();
				q.take();
				q.take();
				q.take();
				q.take();
			}
		},"t3").start();
		
		new Thread(new Runnable() {
			@Override
			public void run() {
				q.take();
				q.take();
				q.take();
				q.take();
				q.take();
			}
		},"t4").start();
	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值