Rxjava2集锦

Rxjava2 基本使用:

    //1、创建被观察者Observable
    Observable<String> observable = Observable.create(new ObservableOnSubscribe<String>() {
        
        public void subscribe(ObservableEmitter<String> e) throws Exception {
            e.onNext("RxJava:e.onNext== 第一次");
            e.onNext("RxJava:e.onNext== 第二次");
            e.onNext("RxJava:e.onNext== 第三次");
            e.onComplete();
        }
    });
 
    //2、创建观察者Observer
    Observer<String> observer = new Observer<String>() {
        
        public void onSubscribe(Disposable d) {
            Log.e(TAG, "onSubscribe == 订阅");
        }
 
        
        public void onNext(String s) {
            Log.e(TAG, "onNext == " + s);
        }
 
        
        public void onError(Throwable e) {
            Log.e(TAG, "onError == " + e.getMessage());
        }
 
        
        public void onComplete() {
            Log.e(TAG, "onComplete == ");
        }
    };
 
    //3、订阅(观察者 观察 被观察者)
    observable.subscribe(observer); 

几种常用的创建操作符总结一下:

创建类型作用备注使用场景
基本创建create()创建一个完成的被观察者(Observable)RxJava中创建被观察者最基本的操作符

1、完整&快速创建被观察者

2、数组、集合遍历

快速创建empty()快速创建后只发送complete事件,直接通知完成
error()快速创建后只发送error事件,直接通知异常
never()快速创建后不发送任何事件
just()快速创建后直接发送传入的事件参数最多只能10个,即发送的事件最多10个
fromArray()快速创建后直接发送传入的数组数据参数为数组,子类型为任意类型,可10个以上
fromIterable()快速创建后直接发送传入的集合List数据参数为集合List,子类型为任意类型,可10个以上
延时创建defer()直到观察者Observer订阅被观察者Observable时,才动态创建被观察者&发送事件通过Observable工厂方法创建被观察者,每次订阅后都会得到一个最新创建的被观察者Observable,确保里面的数据是最新的

1、定时操作

2、周期性操作

timer()快速创建被观察者,指定延时时间,发送一个数值为0的事件延时指定时间后发送一个参数为0的事件,相当于onNext(0)
interval()快速创建被观察者,每隔指定时间发送事件发送事件序列,从0开始,无限递增1
intervalRange()快速创建被观察者,每隔指定时间发送事件,可指定发送事件数发送无限递增1的事件序列,可指定起始值大小和事件次数,可延时,类似interval()
range()快速创建被观察者,连续发送一个时间序列,可指定范围发送无限递增1的事件序列,可指定起始值大小和事件次数,不可延时,类似intervalRange()
rangeLong()同上,区别在于数据参数为类型Long同上

Scheduler调度者:

RxJava中内置了很多线程项供我们选择:

  • Schedulers.io(): 代表IO操作的线程,通常用于网络、读写文件等IO密集型的操作。行为模式和new Thread()差不多,只是IO的内部是一个无上限的线程池,可重用空闲的线程,更高效(不要把计算工作放在IO内,可以避免创建不必要的线程);
  • AndroidSchedulers.mainThread():Android的主线程;用于更新UI
  • Schedulers.newThread(): 总是启用新线程,并在新线程中执行操作;多用于耗时操作
  • Schedulers.computation(): 代表CPU计算密集型的操作,即不会被IO等操作限制性能的操作。
    Observable<String> observable = Observable.create(new ObservableOnSubscribe<String>() {
        
        public void subscribe(ObservableEmitter<String> e) throws Exception {
            e.onNext("RxJava:e.onNext== 第一次");       
            e.onComplete();
            Log.d(TAG, "subscribe()线程==" + Thread.currentThread().getId());
        }
    })
    .subscribeOn(Schedulers.io())//指定被观察者subscribe()(发送事件的线程)在IO线程()
    .observeOn(AndroidSchedulers.mainThread());//指定观察者接收响应事件的线程在主线程

不涉及到下游业务时,不需要Observer:

Observable.just(1)
    .map(new Function<Integer, Integer>() {
        
        public Integer apply(Integer integer) throws Exception {
            SharedDatabase.initDatabase(Utils.getApp()).sharedUserDao().updateLocation(gis_x, gis_y);
            return 1;
        }
    })
    .subscribeOn(Schedulers.io())
    .observeOn(AndroidSchedulers.mainThread())
    .doOnError(new Consumer<Throwable>() {
        
        public void accept(Throwable throwable) throws Exception {
            //Log.e("POLICESERVICE",throwable);
        }
    })
    .subscribe();

concat 组合操作符

https://www.jianshu.com/p/c2a7c03da16d

组合多个观察者:concat() / concatArray()

  • 作用:组合多个 被观测者 一起发送数据,合并后 按发送顺序串行执行
  • 两者的区别:组合被观察者的数量,concat()组合被观察者 <=4,而 concatArray()则可以>=5
public static Observable<ResponseResult<UserInfo>> signin(Map<String, String> map) {
        return Observable.concat(
	        RxUtils.checkNetworkConnection(), 
	        RestServiceCreator.getTokenApiService(false, null).signin(map
        ));
    }
  public static Observable checkNetworkConnection(){
        return Observable.create(new ObservableOnSubscribe<Object>() {
            
            public void subscribe(ObservableEmitter<Object> emitter) throws Exception {
                if (!NetworkUtils.isNetworkConnected()){
                    emitter.onError(new Throwable(StringUtils.getString(R.string.no_network_connection)));
                }
                emitter.onComplete();
            }
        });

    }
   ("app/archives/addArchives")
    Observable<ResponseResult<Object>> addArchives( PatientInfo patientInfo);

循环执行异步方法,等所有方法执行完成后汇总异步请求的结果:

private void upload2Center(List<File> positionFileList){
	 Observable.fromIterable(positionFileList)
                .flatMap(posFile -> {
                    return getHeartChrcObservable(posFile);
                })
                .subscribeOn(Schedulers.io())// 指定异步操作的线程
                .subscribe(
	                results -> {
	                    resultsList.add(results);// 当有结果时添加到列表中
	                }, 
	                error -> { /* 处理错误 */
	                    Log.w("caowj", "异常信息:" + error);
	                },
	                () -> { // 当所有事件都完成时,汇总 resultsList 中的数据
	                    Log.w("caowj", "汇总数据总量:" + resultsList.size());
	                }
        );
}
    public static Observable<int[]> getHeartChrcObservable(File posFile) {
        return Observable.create(new ObservableOnSubscribe<int[]>() {
            
            public void subscribe(ObservableEmitter<int[]> emitter) throws Exception {
                AlgoManager.getInstance().getHeartChrc(posFile, new IPeakCallback() {
                    
                    public void onError(String err) {
                        emitter.onError(new Exception(err)); // 将错误转换为 Exception 发送
                    }

                    
                    public void onFileInfo(int[] results) {
                        emitter.onNext(results); // 发送结果
                        emitter.onComplete(); // 表示这个 Observable 完成了(假设每个 posFile 只对应一个结果)
                    }
                });
            }
        }).subscribeOn(Schedulers.io()); // 指定订阅操作在 IO 线程上执行
    }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用\[2\]:上面我们介绍了了关于RxJava的基本的概念和使用方式,在下面的文章中我们会按照以上定义的顺序从API的角度来讲解以下RxJava各个模块的使用方法。引用\[3\]:retry使用了一种错误重试机制,它可以在出现错误的时候进行重试,我们可以通过参数指定重试机制的条件。以下面的程序为例,这里我们设置了当出现错误的时候会进行2次重试,因此,第一次的时候出现错误会调用onNext,重试2次又会调用2次onNext,第二次重试的时候因为重试又出现了错误,因此此时会触发onError方法。也就是说,下面这段代码会触发onNext3次,触发onError()1次。 问题: rxjava2 defer是什么意思? 回答: 在RxJava2中,defer是一个非常有用的操作符。它允许我们在每次订阅时创建一个新的Observable,以便能够动态地生成Observable。defer操作符接受一个Observable的工厂函数作为参数,当有观察者订阅时,它会调用这个工厂函数创建一个新的Observable。这样,每次订阅时都会得到一个全新的Observable实例,可以确保每个订阅者都能够获取到最新的数据。defer操作符的使用场景包括延迟创建Observable、动态地生成Observable等。 #### 引用[.reference_title] - *1* *2* *3* [RxJava 系列-1:一篇的比较全面的 RxJava2 方法总结](https://blog.csdn.net/weixin_34411563/article/details/87985915)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值