设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 重新 试卷 文件
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

鸟瞰 Java 并发框架(3)

发布时间:2019-07-18 12:57 所属栏目:21 来源:唐尤华
导读:8. RxJava 这与上面的情况类似,唯一的区别是 RxJava 提供了更好的 DSL 可以进行流式编程,下面的例子中没有体现这一点。 性能优于 CompletableFuture 处理并行任务。 8.1 何时使用? 如果编码的场景适合异步非阻塞

8. RxJava

  • 这与上面的情况类似,唯一的区别是 RxJava 提供了更好的 DSL 可以进行流式编程,下面的例子中没有体现这一点。
  • 性能优于 CompletableFuture 处理并行任务。

8.1 何时使用?

如果编码的场景适合异步非阻塞方式,那么可以首选 RxJava 或任何响应式开发库。还具有诸如 back-pressure 之类的附加功能,可以在生产者和消费者之间平衡负载。

  1. int userId = new Random().nextInt(10) + 1; 
  2. ExecutorService executor = CustomThreads.getExecutorService(8); 
  3.  
  4. // I/O 任务 
  5. Observable<String> postsObservable = Observable.just(userId).map(o -> JsonService.getPosts()) 
  6. .subscribeOn(Schedulers.from(executor)); 
  7. Observable<String> commentsObservable = Observable.just(userId).map(o -> JsonService.getComments()) 
  8. .subscribeOn(Schedulers.from(executor)); 
  9. Observable<String> albumsObservable = Observable.just(userId).map(o -> JsonService.getAlbums()) 
  10. .subscribeOn(Schedulers.from(executor)); 
  11. Observable<String> photosObservable = Observable.just(userId).map(o -> JsonService.getPhotos()) 
  12. .subscribeOn(Schedulers.from(executor)); 
  13.  
  14. // 合并来自 /posts 和 /comments API 的响应 
  15. // 作为这个操作的一部分,将执行内存中的一些任务 
  16. Observable<String> postsAndCommentsObservable = Observable 
  17. .zip(postsObservable, commentsObservable, 
  18. (posts, comments) -> ResponseUtil.getPostsAndCommentsOfRandomUser(userId, posts, comments)) 
  19. .subscribeOn(Schedulers.from(executor)); 
  20.  
  21. // 合并来自 /albums 和 /photos API 的响应 
  22. // 作为这个操作的一部分,将执行内存中的一些任务 
  23. Observable<String> albumsAndPhotosObservable = Observable 
  24. .zip(albumsObservable, photosObservable, 
  25. (albums, photos) -> ResponseUtil.getAlbumsAndPhotosOfRandomUser(userId, albums, photos)) 
  26. .subscribeOn(Schedulers.from(executor)); 
  27.  
  28. // 构建最终响应 
  29. Observable.zip(postsAndCommentsObservable, albumsAndPhotosObservable, (r1, r2) -> r1 + r2) 
  30. .subscribeOn(Schedulers.from(executor)) 
  31. .subscribe((response) -> asyncResponse.resume(response), e -> asyncResponse.resume("error")); 

9. Disruptor

鸟瞰 Java 并发框架

[Queue vs RingBuffer]

鸟瞰 Java 并发框架

图片1:http://tutorials.jenkov.com/java-concurrency/blocking-queues.html

图片2:https://www.baeldung.com/lmax-disruptor-concurrency

  • 在本例中,HTTP 线程将被阻塞,直到 disruptor 完成任务,并且使用 countdowlatch 将 HTTP 线程与 ExecutorService 中的线程同步。
  • 这个框架的主要特点是在没有任何锁的情况下处理线程间通信。在 ExecutorService 中,生产者和消费者之间的数据将通过 Queue传递,在生产者和消费者之间的数据传输过程中涉及到一个锁。Disruptor 框架通过一个名为 Ring Buffer 的数据结构(它是循环数组队列的扩展版本)来处理这种生产者-消费者通信,并且不需要任何锁。
  • 这个库不适用于我们在这里讨论的这种用例。仅出于好奇而添加。

9.1 何时使用?

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读