[RxJava学习]操作符Do的使用

时间:2021-04-04 17:50:52

 Observable中Do系列的函数,是通过注册回调的方式,来侦听链式操作过程的各个动作节点。 
函数名 函数用途 函数原型
doOnNext 在每次发射元素之前(调用subScriber.onNext())做一些额外的事情,不改变发射元素的值,只是插入了一个侦听 Observable<T> doOnNext(final Action1<? super T> onNext)
doOnCompleted 在发射完成通知之前做一些额外的事情,不改变原有逻辑流,只是插入了一个侦听 Observable<T> doOnCompleted(final Action0 onCompleted)
doOnError 在发射错误通知之前做一些额外的事情,不改变原有逻辑流,只是插入了一个侦听 Observable<T> doOnError(final Action1<Throwable> onError)
doOnTerminate 在发射通知之前做一些额外的事情(即对onError和onCompleted的调用进行了侦听) Observable<T> doOnTerminate(final Action0 onTerminate)
doOnEach 对发射元素和发射通知进行了统一的封装,用于在发射元素或者发射通知之前做一些额外的事情 Observable<T> doOnEach(final Action1<Notification<? super T>> onNotification)Observable<T> doOnEach(Observer<? super T> observer)
doOnRequest 通常用于跟踪调试,当订阅者开始请求数据时,可以通过这个方法进行侦听,一般是每subscribe一个订阅者就会触发一次 Observable<T> doOnRequest(final Action1<Long> onRequest)
doOnSubscribe 当订阅者订阅时,可以通过这个方法侦听,它会早于doOnRequest被调用 Observable<T> doOnSubscribe(final Action0 subscribe)
doOnUnsubscribe 当订阅者取消订阅时,可以通过这个方法侦听 Observable<T> doOnUnsubscribe(final Action0 unsubscribe)

下面是本次学习的用例:

    private void testOperDo(){
        String SDCARD = Environment.getExternalStorageDirectory().toString();
        ArrayList<File> folders = new ArrayList<>();
        folders.add(new File(SDCARD + File.separator + "BangBang" + File.separator));
        Observable observable12 = Observable.from(folders)
                .flatMap(new Func1<File, Observable<File>>() {
                    @Override
                    public Observable<File> call(File file) {
                        Log.e("chwn", "flatMap>>call:" + file.getName());
                        if(file.isDirectory()) {
                            return Observable.from(file.listFiles());
                        } else{
                            return Observable.just(file);
                        }
                    }
                }).doOnRequest(new Action1<Long>() {
                    @Override
                    public void call(Long aLong) {
                        Log.e("chwn", "doOnRequest>>" + aLong);
                    }
                }).doOnEach(new Action1<Notification<? super File>>() {
                    @Override
                    public void call(Notification<? super File> notification) {
                        Log.e("chwn", "doOnEach>>kind:" + notification.getKind());
                        if(notification.isOnNext()){
                            Log.e("chwn", "doOnEach>>" + notification.getValue().toString());
                        }
                    }
                }).doOnNext(new Action1<File>() {
                    @Override
                    public void call(File file) {
                        Log.e("chwn", "doOnNext>>" + file.getName());
                    }
                }).doOnSubscribe(new Action0() {
                    @Override
                    public void call() {
                        Log.e("chwn", "doOnSubscribe>>" + SystemClock.currentThreadTimeMillis());
                    }
                });
        observable12.subscribe(new Action1<File>() {
            @Override
            public void call(File file) {
                Log.e("chwn", "subscribe1>>" + file.getName());
            }
        });
        folders.add(new File(SDCARD + File.separator + "Pictures"+File.separator));
        observable12.subscribe(new Action1<File>() {
            @Override
            public void call(File file) {
                Log.e("chwn", "subscribe2>>" + file.getName());
            }
        });
    }