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
......