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

62ba45842b374d39e7db782c0ed8bd42.png

繁星点点滴滴

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


版权声明:本文为weixin_42539973原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。