RxJava 学习进行中 -Range&GroupBy

RX

1.Range

Range操作符发射一个范围内的有序整数序列,你可以指定范围的起始和长度。
RxJava将这个操作符实现为range函数,它接受两个参数,一个是范围的起始值,一个是范围的数据的数目。如果你将第二个参数设为0,将导致Observable不发射任何数据(如果设置为负数,会抛异常)。
range默认不在任何特定的调度器上执行。有一个变体可以通过可选参数指定Scheduler。

这个操作符还是挺简单的。

int start = 0;
int end = 30;
Observable.range(start,end, Schedulers.newThread()).subscribe(new Action1<Integer>() {
      @Override
      public void call(Integer integer) {
           Log.d("range","now = "+integer);
      }
});

在一瞬间将0~29按顺序发送出来了


Paste_Image.png

2.GroupBy

将一个Observable分拆为一些Observables集合,它们中的每一个发射原始Observable的一个子序列,GroupBy操作符将原始Observable分拆为一些Observables集合,它们中的每一个发射原始Observable数据序列的一个子序列。哪个数据项由哪一个Observable发射是由一个函数判定的,这个函数给每一项指定一个Key,Key相同的数据会被同一个Observable发射。

GroupByFunc1()函数中按你的逻辑分组,并将每个信息对应的组的key标志返回,如例子中我每个标志都是Integer类型的,GroupBy会返回Observable的一个特殊子类GroupedObservable,这个特殊子类有个额外的方法getKey(),可用于获得当前信息的组别。

实践出真知
先构造了三个类A,B,C,用一个List装了他们的若干个实例,随机的,再使用Observer发射出去,经过GroupBy的作用后打印结果。

        ArrayList list = new ArrayList<Object>();
        list.add(new A());
        list.add(new B());
        list.add(new C());
        list.add(new C());
        list.add(new B());
        list.add(new A());
        list.add(new C());

        Observable from = Observable.from(list);
        from.groupBy(new Func1<Object,Integer>() {
            @Override
            public Integer call(Object o) {
                String name = o.getClass().getName();
                String a = A.class.getName();
                String b = B.class.getName();
                String c = C.class.getName();
                if (name.equals(a)){
                    return  1;
                }else if(name.equals(b)){
                    return  2;
                }else if(name.equals(c)){
                    return  3;
                }
                return 4;
            }
        }).subscribe(new Action1<GroupedObservable<Integer,Object>>() {
            @Override
            public void call(GroupedObservable<Integer,Object> objectIntegerGroupedObservable) {
                int sign = objectIntegerGroupedObservable.getKey();

                switch (sign){
                    case 1:
                        objectIntegerGroupedObservable.subscribe(new Action1<Object>() {
                            @Override
                            public void call(Object a) {
                                Log.d("groupby","class A - "+a.getClass().getName());
                            }
                        });
                        break;
                    case 2:
                        objectIntegerGroupedObservable.subscribe(new Action1<Object>() {
                            @Override
                            public void call(Object a) {
                                Log.d("groupby","class B - "+a.getClass().getName());
                            }
                        });

                        break;
                    case 3:
                        objectIntegerGroupedObservable.subscribe(new Action1<Object>() {
                            @Override
                            public void call(Object a) {
                                Log.d("groupby","class C - "+a.getClass().getName());
                            }
                        });

                        break;
                    default:
                        Log.d("groupby","other class");
                        break;
                }
            }
        });

Paste_Image.png

groupBy(Func1 func1,Func1 func2)
作用跟单个参数的差不多,唯一差别是第二个Func1()则是用来变换返回的信息的

如果将上面的groupBy()换成:

        from.groupBy(new Func1<Object, Integer>() {
            @Override
            public Integer call(Object o) {
                String name = o.getClass().getName();
                String a = A.class.getName();
                String b = B.class.getName();
                String c = C.class.getName();
                if (name.equals(a)){
                    return  1;
                }else if(name.equals(b)){
                    return  2;
                }else if(name.equals(c)){
                    return  3;
                }
                return 4;
            }
        }, new Func1<Object, Integer>() {
            @Override
            public Integer call(Object o) {
                String name = o.getClass().getName();
                String a = A.class.getName();
                String b = B.class.getName();
                String c = C.class.getName();
                if (name.equals(a)){
                    return  1;
                }else if(name.equals(b)){
                    return  2;
                }else if(name.equals(c)){
                    return  3;
                }
                return 4;
            }
        }).subscribe(new Action1<GroupedObservable<Integer,Object>>() {
            @Override
            public void call(GroupedObservable<Integer,Object> objectIntegerGroupedObservable) {
                //...略...
            }
        });

结果打印的信息的类型都是Integer

Paste_Image.png

因为我们第二个Func1()返回的是Integer类型。

官方文档说的挺粗浅的,但只有你实际运用到手上了才能更深刻的理解它能做什么。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 注:只包含标准包中的操作符,用于个人学习及备忘参考博客:http://blog.csdn.net/maplejaw...
    小白要超神阅读 2,241评论 2 8
  • 作者: maplejaw本篇只解析标准包中的操作符。对于扩展包,由于使用率较低,如有需求,请读者自行查阅文档。 创...
    maplejaw_阅读 45,846评论 8 93
  • 响应式编程简介 响应式编程是一种基于异步数据流概念的编程模式。数据流就像一条河:它可以被观测,被过滤,被操作,或者...
    说码解字阅读 3,127评论 0 5
  • 版权声明:本文为小斑马伟原创文章,转载请注明出处! 上篇简单的阐述了响应式编程的基本理论。这篇主要对响应编程进行详...
    ZebraWei阅读 2,562评论 0 2
  • RxJava正在Android开发者中变的越来越流行。唯一的问题就是上手不容易,尤其是大部分人之前都是使用命令式编...
    刘启敏阅读 1,925评论 1 7