RxJava 操作符之 -- 变换操作符

本贴最后更新于 2796 天前,其中的信息可能已经水流花落

buffer

定期收集 Observable 的数据放进一个数据包裹,然后发射这些数据包裹,而不是一次发射一个值。

Observable.range(1,5).buffer(2).subscribe(new Observer<List<Integer>>() {  
              @Override  
              public void onCompleted() {  
                 System.out.println("onCompleted");
              }  

              @Override  
              public void onError(Throwable e) {  
                 System.out.println("onError");
              }  

              @Override  
              public void onNext(List<Integer> i) {  
                 System.out.println("onNext"+i);
              }  
          });

结果

onNext[1, 2]
onNext[3, 4]
onNext[5]
onCompleted

flatMap

FlatMap 将一个发射数据的 Observable 变换为多个 Observables,然后将它们发射的数据合并后放进一个单独的 Observable

Observable.just("大","小")
			.flatMap(new Func1<String, Observable<String>>() {

				@Override
				public Observable<String> call(String t) {
					return Observable.just(t+"sb");
				}
			}).subscribe(new Action1<String>() {

				@Override
				public void call(String t) {
					System.out.println(t);
				}
			});

结果

大sb
小sb

map

对 Observable 发射的每一项数据应用一个函数,执行变换操作

Observable.just("小","大")
		.map(new Func1<String, String>() {

			@Override
			public String call(String t) {

				return t+"sb";
			}
		}).subscribe(new Action1<String>() {

			@Override
			public void call(String t) {
				System.out.println(t);

			}
		});

结果

小sb
大sb

groupBy

将一个 Observable 分拆为一些 Observables 集合,它们中的每一个发射原始 Observable 的一个子序列

Observable.interval(1, TimeUnit.SECONDS).take(10).groupBy(new Func1<Long, Long>() {

      @Override
      public Long call(Long t) {
        //按照key为0,1,2分为3组
        return t % 3;
      }
    }).subscribe(new Action1<GroupedObservable<Long, Long>>() {

      @Override
      public void call(GroupedObservable<Long, Long> result) {
        result.subscribe(new Action1<Long>() {

          @Override
          public void call(Long t) {
            System.out.println("key:" + result.getKey() +", value:" + t);

          }
        });
      }
    });
      try {
        Thread.sleep(Integer.MAX_VALUE);
      } catch (InterruptedException e1) {
        e1.printStackTrace();
      }

结果

key:0, value:0
key:1, value:1
key:2, value:2
key:0, value:3
key:1, value:4
key:2, value:5
key:0, value:6
key:1, value:7
key:2, value:8
key:0, value:9

scan

连续地对数据序列的每一项应用一个函数,然后连续发射结果

Observable.just(1,2,3,4,5).scan(new Func2<Integer, Integer, Integer>() {

			@Override
			public Integer call(Integer t1, Integer t2) {
				// TODO Auto-generated method stub
				return t1+t2;
			}
		}).subscribe(new Subscriber<Integer>() {
	        @Override
	        public void onNext(Integer item) {
	            System.out.println("Next: " + item);
	        }

	        @Override
	        public void onError(Throwable error) {
	            System.err.println("Error: " + error.getMessage());
	        }

	        @Override
	        public void onCompleted() {
	            System.out.println("Sequence complete.");
	        }
	    });

结果

Next: 1
Next: 3
Next: 6
Next: 10
Next: 15
Sequence complete.

window

定期将来自原始 Observable 的数据分解为一个 Observable 窗口,发射这些窗口,而不是每次发射一项数据

Observable.interval(1, TimeUnit.SECONDS).take(12)
    .window(3,TimeUnit.SECONDS)
    .subscribe(new Action1<Observable<Long>>() {

      @Override
      public void call(Observable<Long> t) {
          System.out.println("subdivide begin......");
                  t.subscribe(new Action1<Long>() {
                      @Override
                      public void call(Long aLong) {
                          System.out.println("Next:" + aLong);
                      }
                  });
      }
    });
    try {
      Thread.sleep(Integer.MAX_VALUE);
    } catch (InterruptedException e1) {
      e1.printStackTrace();
    }

结果

subdivide begin......
Next:0
Next:1
subdivide begin......
Next:2
Next:3
Next:4
subdivide begin......
Next:5
Next:6
Next:7
subdivide begin......
Next:8
Next:9
Next:10
subdivide begin......
Next:11

代码

  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3187 引用 • 8213 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...