java reactor 多线程_java - 如何在Reactor中进行多线程文件处理 - 堆栈内存溢出

我希望在列表中找到处理管道的输出,但是程序会立即退出。

那里的代码在主线程上建立了反应链,然后在主线程上没有执行任何操作。 因此,主线程完成了其工作,并且由于boundedElastic()线程是守护程序线程,因此没有其他线程阻止程序退出,因此它退出了。

您可以通过一个更简单的示例看到相同的行为:

Flux f = Flux.just(1, 2, 3, 4, 5)

.delayElements(Duration.ofMillis(500));

f.subscribe(System.out::println);

您当然可以调用newBoundedElastic("name", false)使其成为非守护程序支持的调度程序,但是随后您必须对其进行跟踪并在处理完成后调用dispose,因此它实际上只是在解决问题(该程序将无限运行,直到您处置调度程序为止。)

快速的'n'肮脏解决方案只是阻塞Flux的最后一个元素,作为程序的最后一行-因此,如果我们添加:

f.blockLast();

...然后程序在退出之前等待最后一个元素被发出,而我们的行为就在此之后。

对于概念的简单证明,这很好。 但是,这在“生产”代码中并不理想。 首先,“无阻塞”是响应式代码中的通用规则,因此,如果您有这样的阻塞调用,则很难确定是否是有意的。 如果添加了其他链,并且还希望它们完成,则必须为每个链添加阻塞呼叫。 那是一团糟,而且不是真正可持续的。

一个更好的解决方案是使用CountDownLatch :

CountDownLatch cdl =

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值