关于rxjava3的信息
本篇文章给大家谈谈rxjava3,以及对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
- 1、android studio 怎么添加rxjava的jar包
- 2、真的有必要用rxjava吗
- 3、RxJava和EventBus的区别
- 4、android 用rxjava和retrofit时怎么解决返回数据类型不一致
android studio 怎么添加rxjava的jar包
将第三方jar包加入到libs文件夹中,打开乎喊工程所在Project Structure,然后选择Dependencies,点击那个加号选择File Dependency ,然后再Libs文件夹中选择要导入的jar包。
两外还蔽早有一种方岁并野法是在project选中jar包点击右键"Add as library",这种方法需要定位到项目的根目录,即build.gradle所在的目录。
dependencies
{
compile files('libs/android-support-v4.jar')
compile files('libs/xxxx.jar')
}
真的有必要用rxjava吗
1、Rxjava逻辑会比较清晰,蛋代码可读性比较差;用在后台的业务处理上,后台业务通常复杂,步骤多,这会让逻辑更清晰,但是前端基本上没有必要用,而且代码可读性比较差;
2、ReTrofit每次发起请求都会创建OkHttp,桥做判不会复用,导致单条数敏改据的请求性能低了一倍以上;
3、Rxjava+ReTrofit组合起来运行的性能非常低,特别是并发的时候,性能更低,测试发现并发100条要胡橘1200ms,不使用的话并发130ms;
4、Rxjava+ReTrofit组合当需要读取本地缓存的时候,读缓存是通过URL作为KEY来读取,这样就需要写两遍的URL,一遍是框架用的,一遍是用于缓存的,使用起来更不方便;
以上是本人使用过程中的经历,有没有高手解惑,目前决定放弃这套组合,自己实现一套
RxJava和EventBus的区别
RxJava和EventBus的区别可分为以下几点:
1、RxJava要比EventBus的应用更广泛,EventBus仅仅是作为一种消息的传递工具,但是RxJava里面几乎可以做任何事情。
2、如果是Android开发的话,可以使用RxAndroid,这是对RxJava的一个扩展,结合sqare公司的retrofit可以很轻松的完成网络的访问。
3、在Android中异步操作一般使用AsycTask来完成,但是AsycTask有很多缺点,如不能方便的终止任务的执行等。
4、RxAndroid完全可以替代AsycTask来完成各种异步操作,而且还有BindActivity和BindFragment方法,你悄掘告根本不需要考虑异步操作时的Activity和Fragment的生命周期问题,还有更加强大的的链式启明调用,可以使程序很简洁。
两者之间的联系:RxJava和EventBus一样也是基散轿于观察者模式,但是使用的场景确实异步数据流的处理。
android 用rxjava和retrofit时怎么解决返回数据类型不一致
1. 首先定义带泛型的返回结果,Retrofit API 的原生结果映射为这种形式:
class ResultT {
String ResultMessage;
int ResultCode;
T Data;
}
2. 处理错误的方法和 @朱诗雄 前辈方法差不多,放到作为备镇静态方法放到 RetroUtil 里,这里 ApiException 为自己定义的一个异常,放入错误码和错误信息(错误码不止一个):
static T ObservableT flatResult(ResultT result) {
return Observable.create(subscriber - {
switch (result.ResultCode) {
case Constants.SUCCESS_CODE:
subscriber.onNext(result.Data);
break;
case Constants.ERROR_CODE:
subscriber.onError(new ApiException(result.ResultCode, result.ResultMessage);
break;
default:
// ...
}
subscriber.onCompleted();
}
});
}
3. 在 API 包装类对于上述 ResultT 格式的返棚嫌回结果,统一调用 flatMap(RetroUtil::flatResult) 后的 API。这样每个 API 的返回结果就是 ObservableData 的形式并且在 errorHandler 中统一处理错误了。
// 接口方法
ObservableResultUser getUserInfo();
// 包装后的方法
ObservableUser getUserInfo() {
return mApi.getUserInfo.flatMap(RetroUtil::flatResult);
}
// 调用时
apiWrapper.getUserInfo()
.subscrible(user - {
// 处理正常逻辑
}, error - {
// 处理错误逻辑和异常,这里封装时通常也会统一处理,
// 提供一个默认的 Action1Throwable 参数,弹出
// throwable 的 message 打印日志仿和粗等
});
[img]关于rxjava3和的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。