Volley的网络请求有内存溢出现象学到的一点知识

今天进行程序内存溢出/泄露测试,使用的是LeakCanary,发现除了几个上一个开发者开发习惯问题(什么都喜欢使用静态变量,而且是public的到处调用)外,基本都是报Volley的错误监听回调有溢出,经过百度后发现是因为RequestQueue重复获取的问题,获取一次就新建一个RequestQueue对象,而之前的还在进行网络请求的的就形成了泄露。

解决方案很简单,把自己的volley工具类定义为单例,RequestQueue使用applicationcontext获取,这样就能保证在app里RequestQueue是唯一的。

具体代码:   

 private static VolleyTool mInstance = null;
    private RequestQueue mRequestQueue;
    private Context mContext;
    private VolleyTool(Context context) {
        mContext = context;
        mRequestQueue = Volley.newRequestQueue(context.getApplicationContext());
    }

    public static synchronized VolleyTool getInstance(Context context) {
        if (mInstance == null) {
            mInstance = new VolleyTool(context);
        }
        return mInstance;
    }

    public RequestQueue getmRequestQueue() {
        if (mRequestQueue == null) {
            mRequestQueue = Volley.newRequestQueue(mContext.getApplicationContext());
        }
        return mRequestQueue;
    }
片段代码,仅供参考。

这里有一个重要的标识符 synchronized,单词的意思是“同步”,表示不管谁在使用,这玩意都是同步的,而用我们的理解,则为锁,当有人访问的时候这个地方就加了锁。这里使用了 static 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值