RxJava一些创建操作符的基本使用

create

使用create操作符从头开始创建一个Observable,给这个操作符传递一个接受观察者作为参数的函数。

Observable.create(new ObservableOnSubscribe<String>() {
    @Override
    public void subscribe(ObservableEmitter<String> emitter) throws Exception {

        try {
        //建议先检查一下观察者的isDisposed状态,以便在没有观察者的时候,让Observable停止发射数据,防止运行昂贵的运算
            if (!emitter.isDisposed()) {
                emitter.onNext("hello create");
            }
            emitter.onComplete();
        }catch (Exception e) {
            emitter.onError(e);
        }
    }
}).subscribe(new Consumer<String>() {
    @Override
    public void accept(String s) throws Exception {
        System.out.println("next = "+s);
    }
}, new Consumer<Throwable>() {
    @Override
    public void accept(Throwable throwable) throws Exception {
        System.out.println("error = "+throwable);
    }
}, new Action() {
    @Override
    public void run() throws Exception {
        System.out.println("create complete");
    }
});

just

创建一个发射指定值的Observable。将单个数据转换为发射这个单个数据的Observable。
它可以接受一至十个参数,返回一个按参数列表顺序发射这些数据的Observable。

Observable.just("hello just")
        .subscribe(new Consumer<String>() {
            @Override
            public void accept(String s) throws Exception {
                System.out.println(s);
            }
        });

from

from可以将其他种类的对象和数据类型转换为Observable。比如Future、Iterable和数组转换成Observable。对于Iterable和数组,产生的Observable会发射Iterable或数组的每一项数据。

Observable.fromArray("hello","from")
        .subscribe(new Consumer<String>() {
            @Override
            public void accept(String s) throws Exception {
                System.out.println(s);
            }
        });

ExecutorService executorService = Executors.newCachedThreadPool();
Future<String> future = executorService.submit(new MyCallable());
//from方法可以接受两个可选参数,分别指定超时时长和时间单位。如果过了指定时长,Future还没有返回一个值,那么这个Observable就会发射错误通知并终止。
Observable.fromFuture(future,4, TimeUnit.SECONDS)
        .subscribe(new Consumer<String>() {
            @Override
            public void accept(String s) throws Exception {

            }
        });
//输出结果
//模拟一些耗时的任务...
// io.reactivex.exceptions.OnErrorNotImplementedException 执行结果报错,说明超时的设置起了作用


 class MyCallable implements Callable<String> {
    @Override
    public String call() throws Exception {
        System.out.println("模拟一些耗时的任务....");
        Thread.sleep(5000);
        return "OK";
    }
}

repeat

创建一个发射特定数据重复多次的Observable。

Observable.just("hello repeat")
        .repeat(3)
        .subscribe(new Consumer<String>() {
            @Override
            public void accept(String s) throws Exception {
                System.out.println("s = "+s);
            }
        });
//执行结果
//s = hello repeat
//s = hello repeat
//s = hello repeat

repeatWhen

repeatWhen不是缓存和重放原始Observable的数据序列,而是有条件地重新订阅和发射原来的Observable。

repeatUtil

直到某个条件就不再重复发射数据。当BooleanSupplier的getAsBoolean()返回false时,表示重复发射上游的Observable;当getAsBoolean()为true时,表示中止重复发射上游的Observable。

final long startTime = System.currentTimeMillis();
Observable.interval(500,TimeUnit.MICROSECONDS)
        .take(5)
        .repeatUntil(new BooleanSupplier() {
            @Override
            public boolean getAsBoolean() throws Exception {
                return System.currentTimeMillis()-startTime > 5000;
            }
        }).subscribe(new Consumer<Long>() {
            @Override
            public void accept(Long aLong) throws Exception {
                System.out.println(aLong);
            }
        });

defer

直到有观察者订阅时才创建Observable,并且为每个观察者创建一个全新的Observable。

Observable observable = Observable.defer(new Callable<ObservableSource<?>>() {
    @Override
    public ObservableSource<?> call() throws Exception {
        return Observable.just("hello defer");
    }
});
observable.subscribe(new Consumer<String>() {

    @Override
    public void accept(String s) throws Exception {
        System.out.println(s);
    }
});

internal

创建一个按固定时间间隔发射整数序列的Observable。
interval操作符返回一个Observable,它按照固定的时间间隔发射一个无限递增的整数序列。
interval默认在computation调度器上执行。

timer

创建一个Observable,它在一个给定的延迟后发射一个特殊的值。
timer操作符创建一个在给定时间段之后返回一个特殊值的Observable。
timer操作符默认在computation调度器上执行。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值