RxJava过滤操作符filter、elementAt、distinct、skip、take、ignoreElements、throttleFirst, buffer

 原 https://blog.csdn.net/qq_36523667/article/details/78761470
Android函数响应式编程——必学的RxJava过滤操作符filter、elementAt、distinct、skip、take、ignoreElements、throttleFirst
2017年12月09日 21:40:00
阅读数:370
之前采用的都是分开的写法,现在想想还是写在一起好。

1.filter:例子中就是过滤大于2的
rx.Observable.just(1,2,3,4).filter(new Func1<Integer, Boolean>() {
    @Override
    public Boolean call(Integer integer) {
        return integer > 2;
    }
}).subscribe(new Action1<Integer>() {
    @Override
    public void call(Integer integer) {
        Log.i("xbh", integer + "");
    }
});
 
输出:
12-09 05:28:52.499 15381-15381/com.hdu.a15058124.homework3 I/xbh: 3
12-09 05:28:52.499 15381-15381/com.hdu.a15058124.homework3 I/xbh: 4

2.elementAt:例子中是取得第3个
rx.Observable.just(1,2,3,4).elementAt(2).subscribe(new Action1<Integer>() {
    @Override
    public void call(Integer integer) {
        Log.i("xbh", integer + "");
    }
});

3.distinct:例子中是把重复的只输出1次
rx.Observable.just(1,2,2,3,4,1,1,1,1).distinct().subscribe(new Action1<Integer>() {
    @Override
    public void call(Integer integer) {
        Log.i("xbh", integer + "");
    }
});

输出:
12-09 05:34:56.823 21013-21013/com.hdu.a15058124.homework3 I/xbh: 1
12-09 05:34:56.823 21013-21013/com.hdu.a15058124.homework3 I/xbh: 2
12-09 05:34:56.823 21013-21013/com.hdu.a15058124.homework3 I/xbh: 3
12-09 05:34:56.824 21013-21013/com.hdu.a15058124.homework3 I/xbh: 4

4.skip、take:例子中skip就是从第3个开始取包括第三个,take就是取第3个之前的不包括第3个
rx.Observable.just(1,2,3,4,5,6,7,8).skip(2).subscribe(new Action1<Integer>() {
    @Override
    public void call(Integer integer) {
        Log.i("xbh", integer + "");
    }
});

输出:
12-09 05:36:47.594 22769-22769/com.hdu.a15058124.homework3 I/xbh: 3
12-09 05:36:47.594 22769-22769/com.hdu.a15058124.homework3 I/xbh: 4
12-09 05:36:47.594 22769-22769/com.hdu.a15058124.homework3 I/xbh: 5
12-09 05:36:47.594 22769-22769/com.hdu.a15058124.homework3 I/xbh: 6
12-09 05:36:47.594 22769-22769/com.hdu.a15058124.homework3 I/xbh: 7
12-09 05:36:47.594 22769-22769/com.hdu.a15058124.homework3 I/xbh: 8

rx.Observable.just(1,2,3,4,5,6,7,8).take(2).subscribe(new Action1<Integer>() {
    @Override
    public void call(Integer integer) {
        Log.i("xbh", integer + "");
    }
});

输出:
12-09 05:39:09.274 24985-24985/? I/xbh: 1
12-09 05:39:09.274 24985-24985/? I/xbh: 2

5.ignoreElements:忽略1,2,3,4,即忽略他的数据元素(也可以理解为onNext事件),另外的都保留。
rx.Observable.just(1,2,3,4).ignoreElements().subscribe(new Subscriber<Integer>() {
    @Override
    public void onCompleted() {
        Log.i("xbh", "任务队列全部完成");
    }

    @Override
    public void onError(Throwable e) {
        Log.i("xbh", "出错了");
    }

    @Override
    public void onNext(Integer s) {
        Log.i("xbh", "触发的事件:" + s);
    }

    @Override
    public void onStart() {
        Log.i("xbh", "开始");
    }
});

输出:
12-09 05:47:30.009 32525-32525/? I/xbh: 开始
12-09 05:47:30.009 32525-32525/? I/xbh: 任务队列全部完成

6.throttleFirst:观察者每过一段时间向被观察者取得一串onNext,但是他只要第一个,另外的全部忽略。
这个例子中第一次当i=0的时候,本来应该执行这个观察者的接受到数据的逻辑了,但是200ms还没过,所以当然不执行。
接下来for循环休息了100ms,100ms后,有两个onNext了,一个里面的值是0,一个是1。但是现在是100ms还是没到200ms。
for循环又休息了100ms,终于到了200ms,但是0,1他只取了第一个,那就是0。
接下来以此类推。
rx.Observable.create(new rx.Observable.OnSubscribe<Integer>() {
    @Override
    public void call(Subscriber<? super Integer> subscriber) {
        for (int i = 0; i < 10; i ++) {
            subscriber.onNext(i);
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        subscriber.onCompleted();
    }
}).throttleFirst(200, TimeUnit.MILLISECONDS).subscribe(new Action1<Integer>() {
    @Override
    public void call(Integer integer) {
        Log.i("xbh", integer + "");
    }
});

输出:
12-09 06:22:36.428 406-406/com.hdu.a15058124.homework3 I/xbh: 0
12-09 06:22:36.629 406-406/com.hdu.a15058124.homework3 I/xbh: 2
12-09 06:22:36.831 406-406/com.hdu.a15058124.homework3 I/xbh: 4
12-09 06:22:37.032 406-406/com.hdu.a15058124.homework3 I/xbh: 6
12-09 06:22:37.234 406-406/com.hdu.a15058124.homework3 I/xbh: 8

7.throttleWithTimeout:这个就是和上面有一点点区别。都是200ms执行一次方法,但是这里的200ms是根据你给他数据的时间开始计时的,如果200ms内你又给了他一个数据,那么之前的数据就会被抛弃,并且重新开始计时。
这个例子中:第一次i=0。0%3=0。所以for循环会睡眠300ms,也就是说在200ms内没有第二个数进来破坏这一切,所以0成功输出。
但是i=1的时候,for循环只会睡眠100ms了,那么1被扔进来后,100ms内又扔了个2进来,所以1被抛弃了,2还被留在这里,又重新开始计时。
也就是说,如果你每个都只睡100ms,那么一个数都不会被输出来。
rx.Observable.create(new rx.Observable.OnSubscribe<Integer>() {
    @Override
    public void call(Subscriber<? super Integer> subscriber) {
        for (int i = 0; i < 10; i ++) {
            subscriber.onNext(i);
            int sleep = 100;
            if (i % 3 == 0) {
                sleep = 300;
            }
            try {
                Thread.sleep(sleep);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        subscriber.onCompleted();
    }
}).throttleWithTimeout(200, TimeUnit.MILLISECONDS).subscribe(new Action1<Integer>() {
    @Override
    public void call(Integer integer) {
        Log.i("xbh", integer + "");
    }
});

输出:
12-09 06:18:20.260 28966-29004/? I/xbh: 0
12-09 06:18:20.761 28966-29004/com.hdu.a15058124.homework3 I/xbh: 3
12-09 06:18:21.265 28966-29004/com.hdu.a15058124.homework3 I/xbh: 6
12-09 06:18:21.768 28966-29004/com.hdu.a15058124.homework3 I/xbh: 9

每个都睡100ms的输出:
12-09 06:26:08.757 3982-3982/com.hdu.a15058124.homework3 I/xbh: 9
buffer操作符的功能:

1:能一次性集齐多个结果到列表中,订阅后自动清空相应结果,直到完全清除

2: 也可以周期性的集齐多个结果到列表中,订阅后自动清空相应结果,直到完全清除


buffer 
例子1: 一次订阅2个



//一次订阅2个
        Observable.range(1,5).buffer(2).subscribe(new Observer<List<Integer>>() {
            @Override
            public void onCompleted() {
                LogUtils.d("-----------------onCompleted:");
            }
 
            @Override
            public void onError(Throwable e) {
                LogUtils.d("----------------->onError:");
            }
 
            @Override
            public void onNext(List<Integer> strings) {
                LogUtils.d("----------------->onNext:" + strings);
            }
        });


显示结果:
02-20 15:52:16.433 15913-15913/com.rxandroid.test1 D/----->: ----------------->onNext:[1, 2]
02-20 15:52:16.433 15913-15913/com.rxandroid.test1 D/----->: ----------------->onNext:[3, 4]
02-20 15:52:16.433 15913-15913/com.rxandroid.test1 D/----->: ----------------->onNext:[5]
02-20 15:52:16.433 15913-15913/com.rxandroid.test1 D/----->: -----------------onCompleted:



例子2:一次全部订阅

  //一次全部订阅
        Observable.range(1,5).buffer(5).subscribe(new Observer<List<Integer>>() {
            @Override
            public void onCompleted() {
                LogUtils.d("-----------------onCompleted:");
            }
 
            @Override
            public void onError(Throwable e) {
                LogUtils.d("----------------->onError:");
            }
 
            @Override
            public void onNext(List<Integer> strings) {
                LogUtils.d("----------------->onNext:" + strings);
            }
        });
结果:
02-20 15:54:56.423 21917-21917/com.rxandroid.test1 D/----->: ----------------->onNext:[1, 2, 3, 4, 5]
02-20 15:54:56.423 21917-21917/com.rxandroid.test1 D/----->: -----------------onCompleted:



例子3:每次剔除一个

  //每次剔除1个
        Observable.range(1, 5).buffer(5, 1).subscribe(new Observer<List<Integer>>() {
            @Override
            public void onCompleted() {
                LogUtils.d("-----------------onCompleted:");
            }
 
            @Override
            public void onError(Throwable e) {
                LogUtils.d("----------------->onError:");
            }
 
            @Override
            public void onNext(List<Integer> strings) {
                LogUtils.d("----------------->onNext:" + strings);
            }
        });

02-20 16:05:53.323 26556-26556/com.rxandroid.test1 D/----->: ----------------->onNext:[1, 2, 3, 4, 5]
02-20 16:05:53.323 26556-26556/com.rxandroid.test1 D/----->: ----------------->onNext:[2, 3, 4, 5]
02-20 16:05:53.323 26556-26556/com.rxandroid.test1 D/----->: ----------------->onNext:[3, 4, 5]
02-20 16:05:53.323 26556-26556/com.rxandroid.test1 D/----->: ----------------->onNext:[4, 5]
02-20 16:05:53.323 26556-26556/com.rxandroid.test1 D/----->: ----------------->onNext:[5]
02-20 16:05:53.323 26556-26556/com.rxandroid.test1 D/----->: -----------------onCompleted:


注意当skip==count的时候,框架认为同一操作,一次就清除了count个元素

Observable.range(1, 5).buffer(5, 5).subscribe(new Observer<List<Integer>>() {
            @Override
            public void onCompleted() {
                LogUtils.d("-----------------onCompleted:");
            }
 
            @Override
            public void onError(Throwable e) {
                LogUtils.d("----------------->onError:");
            }
 
            @Override
            public void onNext(List<Integer> strings) {
                LogUtils.d("----------------->onNext:" + strings);
            }
        });


02-20 16:09:24.343 14991-14991/com.rxandroid.test1 D/----->: ----------------->onNext:[1, 2, 3, 4, 5]
02-20 16:09:24.343 14991-14991/com.rxandroid.test1 D/----->: -----------------onCompleted:


例子4:周期性订阅多个结果

 Observable.create(new Observable.OnSubscribe<String>() {
            @Override
            public void call(Subscriber<? super String> subscriber) {
                if (subscriber.isUnsubscribed()) return;
                while (true) {
                    subscriber.onNext("消息" + SystemClock.elapsedRealtime());
                    SystemClock.sleep(2000);//每隔2s发送消息
                }
 
            }
        }).subscribeOn(Schedulers.io()).
                buffer(3, TimeUnit.SECONDS).//每隔3秒 取出消息
                subscribe(new Observer<List<String>>() {
            @Override
            public void onCompleted() {
                LogUtils.d("-----------------onCompleted:");
            }
 
            @Override
            public void onError(Throwable e) {
                LogUtils.d("----------------->onError:");
            }
 
            @Override
            public void onNext(List<String> strings) {
                LogUtils.d("----------------->onNext:" + strings);
            }
        });


02-20 16:55:33.283 17087-18151/com.rxandroid.test1 D/----->: ----------------->onNext:[消息370507667, 消息370509668]
02-20 16:55:36.323 17087-18151/com.rxandroid.test1 D/----->: ----------------->onNext:[消息370511668]
02-20 16:55:39.303 17087-18151/com.rxandroid.test1 D/----->: ----------------->onNext:[消息370513669, 消息370515669]
02-20 16:55:54.883 23122-23316/com.rxandroid.test1 D/----->: ----------------->onNext:[消息370529168, 消息370531172]
02-20 16:55:57.863 23122-23316/com.rxandroid.test1 D/----->: ----------------->onNext:[消息370533184]
02-20 16:56:00.883 23122-23316/com.rxandroid.test1 D/----->: ----------------->onNext:[消息370535184, 消息370537184]
02-20 16:56:03.863 23122-23316/com.rxandroid.test1 D/----->: ----------------->onNext:[消息370539184]
02-20 16:56:06.863 23122-23316/com.rxandroid.test1 D/----->: ----------------->onNext:[消息370541185, 消息370543204]
02-20 16:56:09.863 23122-23316/com.rxandroid.test1 D/----->: ----------------->onNext:[消息370545204]
02-20 16:56:12.863 23122-23316/com.rxandroid.test1 D/----->: ----------------->onNext:[消息370547204, 消息370549204]
02-20 16:56:15.863 23122-23316/com.rxandroid.test1 D/----->: ----------------->onNext:[消息370551204]

猜你喜欢

转载自blog.csdn.net/u013297881/article/details/81287337