天天看點

RxJava/RxAndroid:ConnectableObservable & replay(int bufferSize, long time, TimeUnit unit)

RxJava/RxAndroid:ConnectableObservable & replay(int bufferSize, long time, TimeUnit unit)

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;

import java.util.concurrent.TimeUnit;

import io.reactivex.Observable;
import io.reactivex.observables.ConnectableObservable;
import io.reactivex.observers.DisposableObserver;

public class MainActivity extends AppCompatActivity {
    private String TAG = "輸出";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        ConnectableObservable<Long> mConnectableObservable = Observable
                .interval(1, TimeUnit.SECONDS)
                .replay(2, 5, TimeUnit.SECONDS);

        mConnectableObservable
                .subscribe(new DisposableObserver<Long>() {
                    @Override
                    public void onNext(Long along) {
                        Log.d(TAG, "onNext1:" + along);
                    }

                    @Override
                    public void onComplete() {
                        Log.d(TAG, "onComplete1");
                    }

                    @Override
                    public void onError(Throwable e) {
                        Log.d(TAG, e.toString());
                    }
                });

        mConnectableObservable.connect();

        mConnectableObservable
                .delaySubscription(5, TimeUnit.SECONDS)
                .subscribe(new DisposableObserver<Long>() {
                    @Override
                    public void onNext(Long along) {
                        Log.d(TAG, "onNext2:" + along);
                    }

                    @Override
                    public void onComplete() {
                        Log.d(TAG, "onComplete2");
                    }

                    @Override
                    public void onError(Throwable e) {
                        Log.d(TAG, e.toString());
                    }
                });
    }
}           

output:

01-26 16:18:45.442 21669-21690/zhangphil.book D/輸出: onNext1:0
01-26 16:18:46.442 21669-21690/zhangphil.book D/輸出: onNext1:1
01-26 16:18:47.442 21669-21690/zhangphil.book D/輸出: onNext1:2
01-26 16:18:48.442 21669-21690/zhangphil.book D/輸出: onNext1:3
01-26 16:18:49.442 21669-21690/zhangphil.book D/輸出: onNext1:4
01-26 16:18:49.444 21669-21691/zhangphil.book D/輸出: onNext2:3
01-26 16:18:49.444 21669-21691/zhangphil.book D/輸出: onNext2:4
01-26 16:18:50.442 21669-21690/zhangphil.book D/輸出: onNext1:5
01-26 16:18:50.442 21669-21690/zhangphil.book D/輸出: onNext2:5
01-26 16:18:51.442 21669-21690/zhangphil.book D/輸出: onNext1:6
01-26 16:18:51.442 21669-21690/zhangphil.book D/輸出: onNext2:6
01-26 16:18:52.442 21669-21690/zhangphil.book D/輸出: onNext1:7
01-26 16:18:52.442 21669-21690/zhangphil.book D/輸出: onNext2:7
01-26 16:18:53.442 21669-21690/zhangphil.book D/輸出: onNext1:8
01-26 16:18:53.442 21669-21690/zhangphil.book D/輸出: onNext2:8
01-26 16:18:54.442 21669-21690/zhangphil.book D/輸出: onNext1:9
01-26 16:18:54.442 21669-21690/zhangphil.book D/輸出: onNext2:9
01-26 16:18:55.442 21669-21690/zhangphil.book D/輸出: onNext1:10
01-26 16:18:55.442 21669-21690/zhangphil.book D/輸出: onNext2:10
01-26 16:18:56.442 21669-21690/zhangphil.book D/輸出: onNext1:11
01-26 16:18:56.442 21669-21690/zhangphil.book D/輸出: onNext2:11
01-26 16:18:57.442 21669-21690/zhangphil.book D/輸出: onNext1:12
01-26 16:18:57.442 21669-21690/zhangphil.book D/輸出: onNext2:12

......
           

繼續閱讀