这段时间公司需要将原项目重构成mvp架构,本人参考了网上一些关于Android的mvp项目说明和demo,再加上自己项目中的一些实际需求,整理了一份mvp的架构。这个架构使用retrofit作为网络框架,使用post请求方式,并在接口请求时加入了缓存机制,使用rxbus替换广播,整个项目重构+测试耗时两个星期左右。
由于本项目参考了其他网友的项目,如有网友发现我引用了自己的项目,可以联系我,我会在文章中进行说明。下面附上项目链接:
https://github.com/gongchenghao/my_mvp_projectgongchenghao/my_mvp_projectgongchenghao/my_mvp_project
这里重点说一下缓存机制,我在查找retrofit的时候,并没有发现retrofit有自带的缓存机制,而网上一些针对retrofit进行缓存的方法大多也是针对get请求的,post请求的基本没有,于是我只能是利用一个缓存的工具类进行缓存,这个工具类可以设置每个接口的缓存时间,缓存到期后会重新从服务器端拿最新数据。
以下是我在项目重构时遇到的一些问题的解决方法:
1:使用retrofit访问网络时需要先创建javabean,对于一些需要拿到Json才能创建JavaBean或者需要看到Json返回的数据的开发来说,这种
封装就显得过犹不及,因此我在初始化retrofit的时候,将addConverterFactory(GsonConverterFactory.create())这个方法注释掉了,
并在APIStores类中将Observable后面的泛型改成ResponseBody:Observable postDaDian(@FieldMap Map map),
这样在ApiCallback的onSuccess()方法中拿到的就是ResponseBody的对象,通过new String(responseBody.string())就能拿到返回的Json
2:为了防止使用Gson解析Json字符串失败导致APP崩溃的问题,在解析Json时需要加上try/catch,对此我创建了DefaultParser泛型类进行统一解析
3:retrofit的缓存问题:通过查阅一些资料我发现retrofit本身并没有提供缓存,因此缓存需要我们自己单独添加。网上的一些示例多是针对get
请求添加缓存,而对于post请求,则很少提到。因此我从网上找了一个ACache的缓存工具类,这个工具类可以设定每个接口的缓存时间,使用相当灵活。
我将ACache与retrofit结合,在用户调用Presenter中的网络请求方法时,如果缓存时间还没到,就直接返回缓存数据。
4:在没有使用rxbus传递消息之前,一般使用广播或者eventbus来传递数据,这次重构直接使用rxbus来替换大部分的广播来发送消息,rxbus可以传递各种
类型的数据,比如javabean,hashmap,arraylist,string等,这个在示例demo中均有示例。之所以说替换大部分广播,是因为项目中用到了闹钟功能,这个
是需要发送广播的。
5:对于在工具类、adapter、dialog中需要访问网络的情况,可以直接调用retrofit的网络请求方法,而不用结合mvp和rxjava,但是需要注意的一点是,在
ApiStores中,应该将之前的Observable postGetIocnList(@FieldMap Map map)中的Observable替换成Call
6:rxbus重复接收到消息的问题:重复注册导致的问题。情景:发送一次消息,收到多次消息。在做列表删除时,删除成功后会调用rxbus发送和接收消息,更新
列表UI。在这里每次创建adapter都会注册rxbus,而每次下拉刷新都会重新创建adapter并注册rxbus,导致rxbus重复注册。解决方法就是每次注册时,把当次
注册的tag加入到ArrayList集合中,下次注册时,遍历集合判断有无该tag,如果有,就不走注册的代码了。
public static boolean isAdded(Class tClass)
{
LogUtils.i("传过来的tClass:"+tClass.toString());
boolean isAdd = false;
for (int i = 0; i
if (tClass.toString().equals(mArrayList.get(i)))
{
isAdd = true;
}
}
return isAdd;
}
网友评论