RxJava入门到精通

Android进阶学习RxJava(五)线程调度者Schedul

2020-10-23  本文已影响0人  郝大富

先介绍Scheduler概念

为什么要切换线程
先来小试牛刀一下
先来不加调度器写法,看看效果

/******************* 线程调度者Scheduler ********************/
public void test_6() {
    Observable.just("abc", "cba")
            .map(new Func1<String, String>() {
                @Override
                public String call(String s) {
                    try {
                        //手动延时 10秒钟,模拟耗时操作
                        Thread.sleep(10000);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    return s;
                }
            })
            .subscribe(new Action1<String>() {
                @Override
                public void call(String s) {
                    LogUtils.e(s);
                }
            });

}

/**********单击事件*********/
@OnClick({R.id.show_toast, R.id.open_rxjava})
public void onViewClicked(View view) {
    switch (view.getId()) {
        case R.id.show_toast:
            ToastUtil.showLong(Test3Activity.this, "Hello World");
            break;
        case R.id.open_rxjava:
            test_6();
            break;
        default:
            break;
    }
}

上正菜,加入Scheduler调度线程
Schedulers.immediate():直接在当前线程运行,相当于不指定线程。这是默认的 Scheduler。
Schedulers.newThread():总是启用新线程,并在新线程执行操作。
Schedulers.io(): I/O 操作(读写文件、读写数据库、网络信息交互等)所使用的 Scheduler。行为模式和 newThread() 差不多,区别在于 io() 的内部实现是是用一个无数量上限的线程池,可以重用空闲的线程,因此多数情况下 io() 比 newThread() 更有效率。不要把计算工作放在 io() 中,可以避免创建不必要的线程。
Schedulers.computation():计算所使用的 Scheduler。这个计算指的是 CPU 密集型计算,即不会被 I/O 等操作限制性能的操作,例如图形的计算。这个 Scheduler 使用的固定的线程池,大小为 CPU 核数。不要把 I/O 操作放在 computation() 中,否则 I/O 操作的等待时间会浪费 CPU。
AndroidSchedulers.mainThread():它指定的操作将在 Android 主线程运行
 Observable.just("abc", "cba")
         .subscribeOn(AndroidSchedulers.mainThread())
         .observeOn(Schedulers.io())
         .map(new Func1<String, String>() {
             @Override
             public String call(String s) {
                 Thread thread = Thread.currentThread();
                 LogUtils.e("Func1_map: "+ thread.getId()+" Name: "+ thread.getName());
                 try {
                     //手动延时 10秒钟,模拟耗时操作
                     LogUtils.e("我是耗时操作");
                     Thread.sleep(10000);
                 } catch (Exception e) {
                     e.printStackTrace();
                 }
                 return s;
             }
         })
         .observeOn(AndroidSchedulers.mainThread())
         .subscribe(new Action1<String>() {
             @Override
             public void call(String s) {
                 Thread thread = Thread.currentThread();
                 LogUtils.e("Action1: "+ thread.getId()+" Name: "+ thread.getName());
                 LogUtils.e(s);
             }
         });


总结

上一篇下一篇

猜你喜欢

热点阅读