最近在做android客户端的统计sdk,为了保证数据统计的准确行,需要把一些基本信息,和无网络情况下用户的操作保存到SqlLite本地数据库中,等待有网了的时候进行传;
基本解决思路,离线操作的数据请求URL和请求参数进行封装,封装到对象中,转化为json存储到SQlLite数据库中;定时任务检测网络情况,如果有网,则把数据库中数据取出,进行网络上传;
取出数据库中请求,就需要处理大量网络请求,同时发送请求的情况,一般来说一个网络请求都会用使用到一个异步线程,大量的线程创建、运行、销毁又造成了系统资源的浪费,而且同时同时new出多个子线程也会造成客户端卡死现象;于是考虑到能不能做个请求队列去进行控制
在这个模型中,有高中低三个优先级信道如下:高优先级--1,中优先级--3,低优先级--2
规则:
1.正常情况下各个优先级使用各自信道(线程)
2.高级信道满载、中、低级信道空置,则高级请求可使用低级信道
构思:
UI线程将期望的网络请求url和参数通过一个封装好的Runnable提交给Service处理(当然也可以交给一个Thread处理,本例使用Service),Service接收到请求,判断优先级,加入到相应线程池中排队。线程池启动线程发起网络请求,最后通过监听器将结果返回给Service,Service发送广播通知UI线程,UI线程更新相关界面,结束。
废话说完,上例子:
首先是封装好的Runnable
- public
class HttpConnRunnable implementsRunnable, Parcelable { -
-
public static final int HIGH_LEVEL 0;= -
public static final int NORMAL_LEVEL 1;= -
public static final int LOW_LEVEL 2;= -
-
private int mPriority //优先级,默认为普通= NORMAL_LEVEL; -
private String "";mUrl = -
-
private HttpConnListener //监听器mListener; -
-
-
public HttpConnRunnable() { -
super(); -
} -
-
public HttpConnRunnable( intpriority) { -
super(); -
mPriority = priority; -
} -
-
@Override -
public void run() { -
Log.i(Thread.currentThread().getName(), "----Start to connect:" + ",mUrl + priority:" + "-----");mPriority + -
try { -
Thread.sleep(10000); -
//TODO:进行网络请求相关操作,并通过listener返回结果 -
mListener.onSucceed("Connected to " + "mUrl + succeed!" ); -
} -
catch (InterruptedException e) { -
e.printStackTrace(); -
} -
Log.i(Thread.currentThread().getName(), "----Finish to connect:"