RX操作符之对Observable发射的数据执行变换操作一(map、cast、flatmap、flatmapiteriable、switchmap)

一、map

Map操作符对原始Observable发射的每一项数据应用一个你选择的函数,然后返回一个发射这些结果的Observable。

 private void testMap() {

        String[]items = {"just1","just2","just3","just4","just5","just6"};

        Observable<String> myObservable = Observable.from(items)
                .map(new Func1<String, String>() {
                    @Override
                    public String call(String s) {
                        return mapInfo(s);
                    }
                });
        Subscriber<String> mySubscriber = new Subscriber<String>() {
            @Override
            public void onNext(String s) {
                System.out.println("onNext................."+s);
            }

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

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

    }

private String mapInfo(String s){
        return  s+" had mapped;";

    }

运行结果:



二、cast

cast操作符将原始Observable发射的每一项数据都强制转换为一个指定的类型,然后再发射数据,它是map的一个特殊版本

注:所相互转换的类之间需要存在某种关系,如继承、实现

  List<Machine> items = new ArrayList<>();
        for (int i=0;i<3;i++){
            items.add(new Computer("computer"+i,"material"+i));
        }

        Observable<Computer> myObservable =
                Observable.from(items)
                .cast(Computer.class);
//              .cast(TestCastEntity.class);

        Subscriber<Computer> mySubscriber = new Subscriber<Computer>() {
            @Override
            public void onNext(Computer s) {
                System.out.println("onNext................."+s.name+".........."+s.material);
            }

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

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

    public class Machine {
        public String name;
        public Machine(String name){
            this.name = name;
        }
    }

    public class Computer extends Machine{
        public String material;
        public Computer(String name,String material){
            super(name);
            this.material = material;
        }
    }

运行结果:



三、encode


encode将一个发射字符串的Observable变换为一个发射字节数组(这个字节数组按照原始字符串中的多字节字符边界划分)的Observable。


四、byLine

byLine将一个发射字符串的Observable变换为一个按行发射来自原始Observable的字符串的Observable。


五、flatmap

FlatMap操作符使用一个指定的函数对原始Observable发射的每一项数据执行变换操作,这个函数返回一个本身也发射数据的Observable,然后FlatMap合并这些Observables发射的数据,最后将合并后的结果当做它自己的数据序列发射。

flatmap通过一个函数将原来的数据的每一项进行转换,并将返回的数据进行Observable包装,然后将所有这些Observable转换成一个Observable发射,所执行的结果可能和元数据items中数据的顺序不一致


private void testFlatMap() {
        Integer[]items = {1,2,3,4,5,6};

        Observable<String> myObservable = Observable.from(items)
                .flatMap(new Func1<Integer, Observable<String>>() {
                    @Override
                    public Observable<String> call(Integer i) {
                        return Observable.just(flatMapInfo(i));
                    }
                });


        Subscriber<String> mySubscriber = new Subscriber<String>() {
            @Override
            public void onNext(String s) {
                System.out.println("onNext................."+s);
            }

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

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

        myObservable.subscribe(mySubscriber);
    }
    
    private String flatMapInfo(Integer i){
        return "flatmap" + i;
    }

运行结果:



六、flatmapiteriable

使用iterable作为源数据再将其转换成多个observable


 Integer[]items = {1,2,3,4,5,6};

        Observable<String> myObservable = Observable.from(items)
                .flatMapIterable(new Func1<Integer, Iterable<? extends String>>() {
                    @Override
                    public Iterable<String> call(Integer integer) {
                        ArrayList<String> strings = new ArrayList<String>();
                        strings.add("iterable"+integer);
                        return strings;
                    }
                });


        Subscriber<String> mySubscriber = new Subscriber<String>() {
            @Override
            public void onNext(String s) {
                System.out.println("onNext................."+s);
            }

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

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

        myObservable.subscribe(mySubscriber);

运行结果:



七、concatMap

concatMap操作符,它类似于最简单版本的flatMap,但是它按次序连接而不是合并那些生成的Observables,然后产生自己的数据序列。


八、switchmap

switchMap操作符。它和flatMap很像,除了一点:当原始Observable发射一个新的数据(Observable)时,它将取消订阅并停止监视产生执之前那个数据的Observable,只监视当前这一个。

 Integer[]items = {1,2,3,4,5,6};

        Observable<String> myObservable = Observable.from(items)
                .switchMap(new Func1<Integer, Observable<String>>() {
                    @Override
                    public Observable<String> call(Integer integer) {
                        return Observable.just(integer+"").subscribeOn(Schedulers.newThread());
                    }
                });


        Subscriber<String> mySubscriber = new Subscriber<String>() {
            @Override
            public void onNext(String s) {
                System.out.println("onNext................."+s);
            }

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

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

        myObservable.subscribe(mySubscriber);

运行结果:




九、split
split操作符将一个发射字符串的Observable转换为另一个发射字符串的Observable,只不过,后者将原始的数据序列当做一个数据流,使用一个正则表达式边界分割它们,然后合并发射分割的结果。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值