gpt4 book ai didi

java - 异步编程和响应式(Reactive)编程

转载 作者:行者123 更新时间:2023-12-04 00:54:08 25 4
gpt4 key购买 nike

这个问题在我脑海里大约有一年。实际上 Asysnchronus 和 Non-blocking 有什么区别。当我们在代码中调用阻塞部分时,它就变成了同步的阻塞,同时它也不是非阻塞的。
如果我们在主线程之外创建另一个线程来进行异步编程,我们必须返回一些值,所以我们必须定义 join() java中的方法和join()是阻塞操作,那么它实际上是异步的吗?
我需要知道以下问题的答案

  • 如果阻塞类似于同步,那么异步和非阻塞之间有什么区别。它应该是相似的吗?如果不是那为什么?
  • 非阻塞的响应式(Reactive)编程是完全异步编程吗?
  • 最佳答案

    考虑 2 个并行算法,生产者和消费者。如果消费者比生产者工作得快,我们必须阻塞消费者算法,直到生产者提供新数据。一般来说,我们有两种方法来阻止消费者:

  • 将消费者实现为线程,并阻塞该线程
  • 将消费者实现为任务,在线程池上运行,并从该任务返回(并告诉生产者在数据准备好时重新启动任务)。

  • 实现消费者的第一种方法是同步的,第二种是异步的。
    现在考虑一个相反的情况:生产者比消费者快。再说一次,我们有两个选择 block 生产者:
  • 将生产者实现为线程并阻塞该线程
  • 将生产者实现为任务,在线程池上运行,并从该任务返回(并告诉消费者在能够接收数据时重新启动生产者任务)。

  • 自然,第一个选项是同步的,第二个是异步的。第二个,定义快速生产者和慢消费者之间交互的异步选项称为 reactive programming。 .
    因此,响应式(Reactive)编程是异步编程的一个子集。有许多不同的协议(protocol)来定义异步 Activity 之间的交互,而响应式(Reactive)编程只是其中的一种,它无法涵盖所有​​可能的异步通信情况。
    我尝试在模块 https://github.com/akaigoro/df4j/tree/API-8/df4j-protocols 中收集异步协议(protocol).可以(重新)发明其他协议(protocol),例如,带或不带背压的字节流,类似于同步 InputStreamOutputStream .我确信任何同步协议(protocol)都有其异步类似物。

    关于java - 异步编程和响应式(Reactive)编程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64033955/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com