java scheduler 未调度,RxJava--Scheduler线程调度

c28b1d86b18b

1.computation:

computation Scheduler适用于和CPU有关的任务,但是不适合那些会造成阻塞的任务,因为computation Scheduler内部会根据CPU核数来创建一个线程池,里面的每个线程会占用一个CPU的核心,从而充分利用CPU的资源;

默认运行在computation上面的操作符是: delay 、timer 、skip 、take等。

2.newThread

newThread Scheduler每次都会新建一个线程, 创建线程会造成稍微的延迟。(性能问题,一般不用)

3.io

io Scheduler类似newThread Scheduler , 不同在于io Scheduler的线程可以被回收利用。io Scheduler内部维持了一个线程池,如果有空闲的线程就会在空闲的线程上执行,否则会创建一个新的线程,当空闲线程60秒后没被利用,空闲线程将会被回收

4.immediate

immediate Scheduler会在当前的线程上立刻执行任务,这会将当前线程上正在进行的任务阻塞。例如:如果用Outer代表代表当前正在执行的任务,用Inner来代表使用immediate Scheduler的任务,执行顺序如下:

Outer start-->Inner start --> Inner end --> Outer end 一般也应该避免使用这个Scheduler。

5.trampoline

trampoline Scheduler 同 immediate Scheduler很像,都会在当前线程上执行任务。但是trampoline 并不是立刻开始执行任务,而是等当前线程上之前的任务执行都结束后再开始执行。如果用Outer 和 Inner来代表当前线程上的任务和使用trampoline Scheduler的任务,执行顺序如下: Outer start --> Outer end -->Inner start --> Inner end

6.from

当内置线程无法满足你的需求的时候, 可以使用Schedulers.from(Executor excutor) ,根据提供的Executor来创建Scheduler。

public class SimpleThreadFactory implements ThreadFactory {

@Override

public Thread newThread(@NonNull Runnable runnable) {

return new Thread(runnable);

}

}

Executor executor = new ThreadPoolExecutor(

2,

2,

2000L,TimeUnit.MILLISECONDS,

new LinkedBlockingDeque(1000),

new SimpleThreadFactory());

Scheduler scheduler = Schedulers.from(executor);

Observable.interval(1,TimeUnit.SECONDS).take(5)

.observeOn(scheduler)

.subscribe(new Action1() {

@Override

public void call(Long aLong) {

Log.e("call","Thread Name: "+Thread.currentThread().getName());

}

});

内部创建了两个线程,并且这两个线程会被回收利用。

09-20 14:16:27.032 19128-19174/com.example.administrator.rxjavademo E/call: Thread Name: Thread-3290

09-20 14:16:28.032 19128-19153/com.example.administrator.rxjavademo E/call: Thread Name: Thread-3286

09-20 14:16:29.031 19128-19174/com.example.administrator.rxjavademo E/call: Thread Name: Thread-3290

09-20 14:16:30.039 19128-19153/com.example.administrator.rxjavademo E/call: Thread Name: Thread-3286

09-20 14:16:31.031 19128-19174/com.example.administrator.rxjavademo E/call: Thread Name: Thread-3290

..............

7.test / TestScheduler

测试调度器在 RxJava2.x 中,原先RxJava1.x的Schedulers.test()被去掉了,想要获得TestScheduler对象可以通过直接new TestScheduler()的方式来实现。

TestScheduler让你可以对调度器的时钟表现进行手动微调。这对依赖精确时间安排的任务的测试很有用处。这个调度器有三个额外的方法:

advanceTimeTo(time,unit) 向前波动调度器的时钟到一个指定的时间点

advanceTimeBy(time,unit) 将调度器的时钟向前拨动一个指定的时间段

triggerActions( ) 开始执行任何计划中的但是未启动的任务,如果它们的计划时间等于或者早于调度器时钟的当前时间

参考:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值