[Reactor] 操作符实践之skip、take

栏目: Java · 发布时间: 6年前

内容简介:skip相关的操作符主要包括skip,skipWhile,skipUntil,skipLast与skip相对应,take相关的操作符主要包括take,takeWhile,takeUntil,takeLast

skip相关方法

skip相关的操作符主要包括skip,skipWhile,skipUntil,skipLast

skip

最简单,顾名思义,跳过前n个元素,如果n超过元素个数,则以元素个数为准

[Reactor] 操作符实践之skip、take
@Test
 public void textSkip() {
     Flux.range(1, 10).skip(3).subscribe(System.out::println);
 }
 
output:
4
5
6
7
8
9
10

skipLast

与skip相反,跳过后n个元素

[Reactor] 操作符实践之skip、take
@Test
    public void textSkip() {
        Flux.range(1, 10).skipLast(3).subscribe(System.out::println);
    }
1
2
3
4
5
6
7

skipWhile

当前n元素都符合predicate的条件,则跳过,直到出现第一个不符合条件的元素

[Reactor] 操作符实践之skip、take
@Test
    public void textSkip() {
        Flux.just(1, 10, 2, 9, 8).skipWhile(n -> n < 7).subscribe(System.out::println);
    }
output
10
2
9
8

skipUntil

当前n元素都不符合predicat的条件,则跳过,直到出现第一个符合条件的元素

[Reactor] 操作符实践之skip、take
@Test
    public void textSkip() {
        Flux.just(10, 1, 2, 9, 8).skipUntil(n -> n < 7).subscribe(System.out::println);
    }
output
1
2
9
8

take相关方法

与skip相对应,take相关的操作符主要包括take,takeWhile,takeUntil,takeLast

take

仅获取前n个元素,如果n超过元素个数,则以元素个数为准

[Reactor] 操作符实践之skip、take
@Test
    public void textTake() {
        Flux.range(1, 10).take(3).subscribe(System.out::println);
    }
output
1
2
3

takeLast

仅获取后n个元素

[Reactor] 操作符实践之skip、take
@Test
    public void textTake() {
        Flux.range(1, 10).takeLast(3).subscribe(System.out::println);
    }
output
8
9
10

takeWhile

仅获取前n元素都符合predicate条件的元素,直到出现第一个不符合条件的元素

[Reactor] 操作符实践之skip、take
@Test
    public void textTake() {
        Flux.range(1, 10).takeWhile(n -> n < 7).subscribe(System.out::println);
    }
output
1
2
3
4
5
6

takeUntil

仅获取前n元素都不符合predicate条件的元素,直到出现第一个符合条件的元素(注意,这个符合要求的元素同样会被获取到)

[Reactor] 操作符实践之skip、take
@Test
    public void textTake() {
        Flux.just(10, 9, 1, 8).takeUntil(n -> n < 7).subscribe(System.out::println);
    }
output
10
9
1

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法基础

算法基础

[美] 托马斯 H.科尔曼(Thomas H.Cormen) / 王宏志 / 机械工业出版社 / 2015-12 / 59.00

本书介绍了什么是计算机算法,如何描述它们,以及如何来评估它们。这些计算机算法将提供:利用计算机搜索信息的简单方式;解决各种排序问题的方法;利用有向无环图和最短路径法来解决基本问题的方法(可用于建模公路网络,任务间的依赖及金融关系);解决字符串(例如DNA结构)问题的方法;密码学背后的基本原理;数据压缩的基础知识;以及甚至一些没有人能够理解如何在计算机上用相当长的时间来解决的问题。 本书适合作......一起来看看 《算法基础》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

URL 编码/解码
URL 编码/解码

URL 编码/解码

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具