一:初上手(填坑)
Observable将事件序列执行完毕后,会回调Observe的onNext()方法和onCompleted()方法,当出现异常/错误时会调用onError()方法。
由此,我们推断,问题出现的地方应该是在Observable的执行过程。
先阐述一下笔者的需求,使用retrofit和rxjava进行简单的网络请求(请求得到的数据自动装配为实体类),后端给的返回格式是标准的Result格式(即status,message,data),前两者相对固定,而data域可能是User对象,Paper对象,也可能是Map/List,而我们想要得到的就是这个data中的数据,那么我们势必需要进行数据的剥离。恰好,RxJava的map(变换)可以实现此需求。
下面,上图:
1.Paper实体类
2.Result结果集实体类
3.定义Retrofit的请求接口
4.创建Retrofit实例
5.由于请求接口定义的返回类型为Observable<...>类型,所以可直接在其上进行rx的链式操作
6.图中的map()方法中的参数是一个自定义的接口,用于 事件变换
7. 图5中的onNext方法中使用自定义接口(如下图),进行数据转发
8.测试
9. 一万个草尼玛,什么鬼。再往下看日志,发现
卧槽,尼玛. 无效的时间指示器(原谅我蹩脚的英文)。且上图的数字,便是json中的日期
10. 由此,笔者便猜测是Gson装配过程中出现的问题,然后通过一番学习,发现Gson默认解析时间时会出现问题,原因未知,有知道的同学可以在评论区留言,互相学习了啦。
解决方案:
GsonBuilder builder = new GsonBuilder(); // Register an adapter to manage the date types as long values builder.registerTypeAdapter(Date.class, new JsonDeserializer<Date>() { public Date deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException { return new Date(json.getAsJsonPrimitive().getAsLong()); } }); Gson gson = builder.create();
然后在下图位置传入gson实例
11. 再次测试
天地良心,终于可以了。下一节,会写一些关于对RxJava和Retrofit的封装。