android volley 超时,android – Volley缓慢而导致内存泄漏

在Android项目中使用Volley库下载JSON流时遇到问题。首次调用正常,但第二次调用出现超时错误。尝试通过设置RetryPolicy延长请求时间,但请求耗时增加至30秒以上,同时伴随着显著的内存消耗。日志显示大量GC活动,可能由于数据量大导致内存分配频繁。在浏览器中请求同一URL则响应快速,表明问题可能与应用内的处理或Volley配置有关。
摘要由CSDN通过智能技术生成

在我的项目中,我使用volley来下载一个JSON流,我将其解析并显示在列表视图中.我使用以下方法加载我的数据:

private void loadEventData(int year, final int month) {

// get volley request queue

requestQueue = cpcApplication.getRequestQueue(getActivity());

String url = "****************?year=" + year

+ "&month=" + month;

pd = ProgressDialog.show(getActivity(), "Loading Events", "Retrieving Data from Server");

pd.setCancelable(true);

JsonObjectRequest jr = new JsonObjectRequest(Request.Method.GET, url, null, new Response.Listener() {

@Override

public void onResponse(JSONObject response) {

Log.i(TAG, response.toString());

// parse the incoming response

parseJson(response, month);

// notify the listview that the data set has changed

adapter.notifyDataSetChanged();

// set the listview at the top position

listView.setSelection(current.get(Calendar.DAY_OF_MONTH));

// dismiss the ProgressDialog

pd.dismiss();

}

}, new Response.ErrorListener() {

@Override

public void onErrorResponse(VolleyError error) {

error.printStackTrace();

// cancel the progress dialog

pd.dismiss();

// let the user know that a network connection is not available

Toast.makeText(getActivity(), "Cannot communicate with server. Check network connection.", Toast.LENGTH_LONG).show();

}

});

// add the network request to the queue

requestQueue.add(jr);

}

对此方法的第一次调用非常有效.在第二次调用中,我收到超时错误.当我使用以下命令时:

jr.setRetryPolicy(new DefaultRetryPolicy(

2500, DefaultRetryPolicy.DEFAULT_TIMEOUT_MS, DefaultRetryPolicy.DEFAULT_BACKOFF_MULT));

为了增加请求的时间,请求超过30秒并产生以下日志输出:

10-19 20:53:19.746: D/Volley(17523): [2786] BasicNetwork.logSlowRequests: HTTP response for request= [lifetime=41769], [size=5467846], [rc=200], [retryCount=2]

10-19 20:53:19.796: D/dalvikvm(17523): GC_CONCURRENT freed 7462K, 26% free 24424K/33000K, paused 6ms+4ms, total 56ms

10-19 20:53:19.796: D/dalvikvm(17523): WAIT_FOR_CONCURRENT_GC blocked 51ms

10-19 20:53:19.826: I/dalvikvm-heap(17523): Grow heap (frag case) to 35.123MB for 10935708-byte allocation

10-19 20:53:19.857: D/dalvikvm(17523): GC_FOR_ALLOC freed 3K, 20% free 35100K/43680K, paused 23ms, total 28ms

10-19 20:53:19.917: D/dalvikvm(17523): GC_CONCURRENT freed 2018K, 19% free 35816K/43680K, paused 3ms+4ms, total 60ms

10-19 20:53:20.007: D/dalvikvm(17523): GC_CONCURRENT freed 4874K, 15% free 37226K/43680K, paused 2ms+3ms, total 27ms

10-19 20:53:20.007: D/dalvikvm(17523): WAIT_FOR_CONCURRENT_GC blocked 24ms

10-19 20:53:20.067: D/dalvikvm(17523): GC_FOR_ALLOC freed 5037K, 15% free 38601K/44900K, paused 19ms, total 19ms

10-19 20:53:20.117: D/dalvikvm(17523): GC_FOR_ALLOC freed 4680K, 14% free 40045K/46564K, paused 20ms, total 20ms

10-19 20:53:20.177: D/dalvikvm(17523): GC_FOR_ALLOC freed 5576K, 14% free 41572K/48272K, paused 20ms, total 20ms

10-19 20:53:20.227: D/dalvikvm(17523): GC_FOR_ALLOC freed 6133K, 15% free 43406K/50548K, paused 20ms, total 20ms

10-19 20:53:20.287: D/dalvikvm(17523): GC_CONCURRENT freed 6486K, 15% free 45029K/52428K, paused 2ms+2ms, total 24ms

10-19 20:53:20.287: D/dalvikvm(17523): WAIT_FOR_CONCURRENT_GC blocked 11ms

10-19 20:53:20.407: D/Volley(17523): [1] Request.finish: 42553 ms: [ ] http://****** 0x63ea5535 NORMAL 1

当我在浏览器中执行相同的请求时,只需几秒钟.为什么延迟和令人难以置信的内存消耗?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值