美文网首页
RxJava--Scheduler线程调度

RxJava--Scheduler线程调度

作者: 特大碗牛肉面 | 来源:发表于2018-09-20 14:35 被阅读0次

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<Runnable>(1000),
        new SimpleThreadFactory());

Scheduler scheduler = Schedulers.from(executor);

Observable.interval(1,TimeUnit.SECONDS).take(5)
        .observeOn(scheduler)
        .subscribe(new Action1<Long>() {
            @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( ) 开始执行任何计划中的但是未启动的任务,如果它们的计划时间等于或者早于调度器时钟的当前时间

参考:

相关文章

  • RxJava--Scheduler线程调度

    1.computation: computation Scheduler适用于和CPU有关的任务,但是不适合那些会...

  • java虚拟机读书笔记之线程调度

    java线程调度 线程调度主要有两种方式,协同式线程调度和抢占式线程调度。1、协同式: 线程的执行时间由线程本身...

  • [Java]线程和锁

    0x00 线程调度 线程调度指的是系统为线程分配CPU使用权。分为两种: 协同式线程调度线程想用CPU多久就用多久...

  • CPU调度

    CPU调度 基本概念 CPU调度在讨论普通调度概念时使用进程调度,特别指定为线程概念时使用线程调度 CPU-I/O...

  • 2018-04-03 线程基础

    线程调度 是指系统分配CPU使用权限的方式,分为协同式线程调度和抢占式线程调度 进程、线程概念 进程是应用程序的一...

  • 线程优先级和守护线程

    线程优先级: Java提供一个线程调度器来监控程序中启动后进入就绪状态的所有线程,线程调度器按照优先级决定调度哪个...

  • 并发--线程和锁

    线程调度 协同式调度 1.一个线程执行完毕之后再通知其他线程执行 抢占式调度(JAVA使用的是这种方式) 1.os...

  • 2.1 Java线程调度

    线程调度是指系统为线程分配处理器使用权的过程,主要调度方式有两种,分别是协同式线程调度(CooperativeTh...

  • 网络编程(三)

    Volley用法完全解析 从上图可以看到Volley分为三个线程,分别是主线程、缓存调度线程、和网络调度线程,首先...

  • EffectiveJava第十章第七节

    不要依赖于线程调度器 当有多个线程可以运行时,由线程调度器(thread scheduler)决定哪些线程将会运行...

网友评论

      本文标题:RxJava--Scheduler线程调度

      本文链接:https://www.haomeiwen.com/subject/xjygnftx.html