为了账号安全,请及时绑定邮箱和手机立即绑定

java里面实现MQ的原理是什么?

java里面实现MQ的原理是什么?

繁花如伊 2019-03-30 18:14:17
我现在想做一个消息队列,一边在不停的放数据,一边在不停的take,怎么保证这个take一直在执行?,是不是要写一个死循环的?还是有别的什么方式?
查看完整描述

3 回答

?
素胚勾勒不出你

TA贡献1827条经验 获得超9个赞

已经搞好了,写了个死循环,谢谢各位。


查看完整回答
反对 回复 2019-04-18
?
浮云间

TA贡献1829条经验 获得超4个赞

假设你是单机模式下


while(true){


object obj = queue.take();//这里会阻塞的

//去做别的处理

}


查看完整回答
反对 回复 2019-04-18
?
繁星点点滴滴

TA贡献1803条经验 获得超3个赞

一般数据的放和收对应的是2个线程或进程,以达到异步的目的使得吞吐量最大化。所以你说的是对的,一个不停的add数据,一个不停的get数据,但这样有一个问题,如果你数据添加过慢或过快,或者数据处理的过慢或过快,都会出现队列空或者队列满的情况,这种情况一旦出现,意味着一方要等另一方完成动作才能继续,降低吞吐量,所以一般是会有一个超时返回的。

下面一个是无超时的消息队列get


public Message receive() throws InterruptedException {

        

        synchronized (queue) {

            

            if(queue.isEmpty()){

                queue.wait(1000);

            }

            if(queue.isEmpty()){

                return null;//timeout

            }

            Message message=queue.get(0);

            queue.remove(0);

            return message;

        }


    }


查看完整回答
反对 回复 2019-04-18
  • 3 回答
  • 0 关注
  • 1066 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信