每个下载文件的任务被封装为一个下载请求。包含下载地址,保存地址,请求头,优先级,tag,读取超时,链接超时,UserAgent。
每个下载任务在开始后会反对应的下载序号,是通过系统的MD5算法返回的,参数为下载地址和文件保存地址生成的,确保唯一。通过这个序号可以进行暂停,恢复,取消,进度监听,完成,失败的回调。
创建的下载任务被保存在ConcurrentHashMap中,key为下载序号,value是下载任务。这样就可以通过下载序号来操作每个下载请求的状态。
下载操作被封装成Runnable,然后使用自定义FutureTask进行包装,并实现了Comparable接口,用于处理优先级,放入自定义的线程池中执行。线程池的主要和最大线程池数均为CPU数量的两倍+1,核心线程数不需要保活。线程池的线程队列采用优先级阻塞队列进行接受下载任务。
下载中的状态都是根据主线程的Handler进行UI交互。下载成功时在通知UI显示后会将下载任务从之前的ConcurrentHashMap中移除。