多线程之间实现同步超时等待获取指定数据

需求:

两个线程,1个生产者,1个消费者,消费者只消费它想要的数据,并且可以等待指定时间,超过给定时间返回null

使用java自带的阻塞队列,LinkedBlockingQueue,但是不能实现消费者他想要的数据,所以自定义一个实现

下列实现有个不好的地方:生产者生产的数据没有对应消费者,数据就会一直增长,如果不重要的数据可以定时清理 

public class InfoChangeCenterManager {
	
	private static final ConcurrentHashMap<String, Object> content=new ConcurrentHashMap<>();
	
	public static boolean putContent(String key,String type,Object value) {
		try {
			synchronized (content) {
				content.put(key+"_"+type, value);
				content.notifyAll();
			}
			return true;
		} catch (Exception e) {
			return false;
		}
	}
	
	public static Object getContent(String key,String type,int timeout) {
		long start=System.currentTimeMillis();
		synchronized (content) {
			String keyType=key+"_"+type;
			while(!content.containsKey(keyType)){
				try {
					if((System.currentTimeMillis()-start)>=timeout*1000){//这里一定要写>=,否则可能导致线程一直等待
						return null;
					}
					long time=timeout*1000-(System.currentTimeMillis()-start);
					content.wait(time);//这里的时间应该是剩余时间
				} catch (Exception e) {
					e.printStackTrace();
				}
			}
			return content.remove(keyType);
		}
	}
	
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值