首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >反应堆3中缺少TopicProcessor的消息

反应堆3中缺少TopicProcessor的消息
EN

Stack Overflow用户
提问于 2017-04-13 12:13:30
回答 1查看 462关注 0票数 1

我正在运行一个简单的测试,将来自4个线程的消息发布到TopicProcessor,而在订阅服务器中,我只需将它们添加到集合中即可。守则如下:

代码语言:javascript
复制
@Test
public void testProcessingMessages() throws Exception {
    int numberOfMessages = 1000;

    TopicProcessor<Integer> processor = TopicProcessor.create();

    ExecutorService executorService = Executors.newFixedThreadPool(4);

    Queue<Integer> messages = new ConcurrentLinkedQueue<>();

    processor.subscribe(messages::add);

    AtomicInteger counter = new AtomicInteger(0);
    for (int i = 0; i < numberOfMessages; i++) {
        executorService.submit(() -> {
            processor.onNext(counter.incrementAndGet());
        });
    }

    Thread.sleep(10000);

    assertEquals(numberOfMessages, messages.size());
}

但是最终断言失败了,通常大约在980-990条实际消息,而不是预期的1000条消息。我是不是遗漏了什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-04-13 13:04:22

问题是,TopicProcessor.create创建了一个处理器,该处理器期望从单个线程发布。从多个线程生成时应使用TopicProcessor.share

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/43392047

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档