令仔学多线程系列----自定义Queue队列
Posted 令仔很忙
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了令仔学多线程系列----自定义Queue队列相关的知识,希望对你有一定的参考价值。
之前做了一个新的需求,需要从每一次search请求返回中获取相关的数据,然后把这些获取到的数据做异步处理,写入缓存并同步到数据库中。如何做异步在这就想到了用队列的方式来实现,一开始是用的BlockingQueue,一遍从队尾push,另一边从队首取数据。
但是在这个地方用BlockingQueue的时候就会有点问题,首先是如果不给这个队列设置大小的话,时间长了很可能会吧内存给搞瘫了,但是如果给BlockingQueue设置了大小的话(ps:当时设置的是2000),我们的主流程是search,其他的业务功能的开发不能够影响到search的运行(PS:每个平台对search返回的时间都有限制的),当队列满了之后,再多来的任务就会被挂起,一直等到队列中有空余位置才会被执行。这样的话我们整个的流程就会Down掉。
所以就自己封装了一个Queue,当队列满了之后,多余的数据就会被扔掉,当然不是所有的业务场景都适合使用。仅供参考借鉴。
下面是具体的代码:
package com.flight.inter.otaadapter.manage;
import java.util.LinkedList;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
/**
* Created by ling.zhang on 16/4/26.
*/
public class LocalCacheQueue<T>
private Lock lock=new ReentrantLock();
private int maxSize;
private int currentSize;
private int size;
private LinkedList<T> requestQueue;
public LocalCacheQueue(int size)
this.size=size;
this.maxSize=2*size;
currentSize=0;
requestQueue=new LinkedList<>();
public T pop()
try
lock.lock();
T getOne=requestQueue.pop();
if(getOne!=null)
currentSize--;
return getOne;
catch (Exception e)
return null;
finally
lock.unlock();
public void push(T one)
try
lock.lock();
if(currentSize>size)
ltrim();
requestQueue.push(one);
currentSize++;
catch (Exception e)
finally
lock.unlock();
private void ltrim()
int needClearSize=currentSize-size;
for(int i=0;i<needClearSize;i++)
try
T getOne = requestQueue.removeLast();
currentSize--;
catch (Exception e)
以上是关于令仔学多线程系列----自定义Queue队列的主要内容,如果未能解决你的问题,请参考以下文章