这段时间公司须要将原项目重构成mvp架构,本人参考了网上一些关于Android的mvp项目说明和demo,再加上本身项目中的一些实际需求,整理了一份mvp的架构。这个架构使用retrofit做为网络框架,使用post请求方式,并在接口请求时加入了缓存机制,使用rxbus替换广播,整个项目重构+测试耗时两个星期左右。java
因为本项目参考了其余网友的项目,若有网友发现我引用了本身的项目,能够联系我,我会在文章中进行说明。下面附上项目连接:git
https://github.com/gongchenghao/my_mvp_projectgongchenghao/my_mvp_projectgongchenghao/my_mvp_projectgithub
这里重点说一下缓存机制,我在查找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泛型类进行统一解析post
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;
}