随着Android的三方库越来越多,且越发稳定的今天,提高用户体验成了很多Android攻城狮的一个重要课题,Boss们也开始吵着 咋又不兼容性了,打开页面很慢 ...等等的问题突如其来,那今天的话题就围绕着 页面加载很慢 这个问题做一些优化的建议,大神们觉得写的不好,可以多多提些意见!

因客户在使用app时的场景十分复杂,特别在弱网或无网情况下还能给客户带来良好的使用感受,无疑会大大增加用户倾爱度~~,其中最有效的方法就是适当的网络缓存和图片缓存的加入。结合目前主流的网络请求(同门的okhttp 与retrofit) ,因retrofit 也可以使用okhttp的缓存机制,所以第一篇主要来讲okhttp的缓存使用。

1.网络请求缓存的使用场景(仅供参考)
基于服务器是否支持(可参考返回的Response中Header是否有Cache-Control", "max-age等参数来简单判断)

下面这张图是square的javadoc上拔下的,很清楚的解释了Interceptors的作用,在服务器返回的Response不支持缓存时,可以通过重写Interceptors来实现缓存的效果,当然服务器返回的Response中有Cache-Control", "max-age=" 的话,就直接设置 .cache(cache)就可以了。
详细的内容参考文档:https://github.com/square/okhttp/wiki/Interceptors

2.具体使用方法
导入okhttp3库:compile'com.squareup.okhttp3:okhttp:3.6.0'
获取一个okhttpClient(代码如下):

package com.example.zq.lottiedemo;import android.content.Context;import android.util.Log;import java.io.IOException;import java.util.concurrent.TimeUnit;import okhttp3.Cache;import okhttp3.Interceptor;import okhttp3.OkHttpClient;import okhttp3.Request;import okhttp3.Response;/** * Created by ZQ on 2017/2/6. */public class MyOkHttp {private  static OkHttpClient mOkHttp;private final static long maxSize = 30 * 1024 * 1024;//最大的缓存空间private MyOkHttp() {}public synchronized staticOkHttpClient newInstance(Context context) {    if (mOkHttp == null) {        //本地缓存的路径和大小        Cache cache = new Cache(context.getCacheDir(), maxSize);        //一些基本设置        mOkHttp = new OkHttpClient.Builder()                //如服务器返回的header中不支持缓存,即可使用网络拦截器,自行添加                .addNetworkInterceptor(new Interceptor() {                    @Override                    public Response intercept(Chain chain) throws IOException {                        Request request = chain.request();                        Log.i("tag", String.format("Sending request %s on %s%n%s",                                request.url(), chain.connection(), request.headers()));                        Response response = chain.proceed(request);                        response = response.newBuilder()                                .removeHeader("Pragma")                                .removeHeader("Cache-Control")                                //cache for two weeks                                .header("Cache-Control", "max-age=" + 3600 * 24 * 14)                                .build();                        return response;                    }                })                .cache(cache)                .connectTimeout(20,TimeUnit.SECONDS)                .readTimeout(20,TimeUnit.SECONDS)                .build();    }    return mOkHttp;}}

更多相关文章

  1. tcping测试服务器TCP端口
  2. 如何用手机访问电脑本地 localhost 网页或者服务器, 以调试web项
  3. 详解Android中那些酷炫返回方式的实现
  4. 将你的老旧Android平板或手机改造成服务器
  5. Android性能优化之三级缓存
  6. Warning:Default Activity not found Android(安卓)studio(网上答
  7. Android第五十一期 - 即时通讯视频聊天
  8. 一个android显示远程txt的代码例子
  9. getSupportActionBar使用报错

随机推荐

  1. Android之qq盗号
  2. Android SDK r16 发布
  3. 一个不错的Android Market网站
  4. android SpannableString使用详解
  5. Android 热修复案例
  6. android 图片背景使用这种方式很爽
  7. Android(安卓)ViewPager 几种开发案例的
  8. Android : Menus Part 3: Alternative Me
  9. Android 自制一个工作日历 原代码
  10. Android = Java ?