- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
?
基于Java多线程的下载器源码剖析(一)
分类:?JavaHYPERLINK /zhzhl202/article/category/1136415多线程2012-04-28 21:29?747人阅读?评论(6)?收藏?举报
多线程HYPERLINK /tag/details.html?tag=javajavaHYPERLINK /tag/details.html?tag=downloaddownloadHYPERLINK /tag/details.html?tag=bytebyteHYPERLINK /tag/details.html?tag=filefileHYPERLINK /tag/details.html?tag=exceptionexception
目录(?)[+]
本文实现了一个基于Java多线程的下载器,可提供的功能有:
1. 对文件使用多线程下载,并显示每时刻的下载速度。2. 对多个下载进行管理,包括线程调度,内存管理等。这篇文章的结构如下:首先讨论如何实现利用Java多线程对单个文件进行下载。然后讨论当系统中有多个文件下载,如何对这些下载进行管理。包括线程调度,内存管理等。
一:单个文件下载的管理
1. 单文件下载类层次
首先简要介绍一下单个文件下载管理的类层次:来一张图来表示。
?
为需要下载的文件创建一个Download类,Download负责管理该文件下载时的线程管理、文件管理、当前速度计算等操作。
根据线程的数目tNum,将该文件分为tNum段,每段为一个DownloadBlock。在实际下载的过程中,并不是一次把所有的东西下载完,而是每次下载固定size的一段Di。所以每个DownloadBlock又会分成n段。
为每个DownloadBlock申请一个线程DownloadThread。其主要作用就是每次下载一段Di,并将其写入到文件中。
2. 单文件下载
对于单个下载,步骤如下
连接资源服务器,获取资源信息,创建文件
?切分资源,为每个线程分配固定的下载区域。
1)封装下载的属性
在建立下载之前,我们把每一次下载进行抽象封装。
首先把URL、目标文件等封装在一个DownloadConfig类中。
其中包含了4个属性:
[java]?view plainHYPERLINK /zhzhl202/article/details/7521377copy
private?URL?url;?//文件下载地址??
private?File?file;?//下载文件保存目标文件??
private?int?nthread;?//下载该文件需要的线程数??
private?int?priority;?//该下载的优先级??
如下如所示:
2)连接资源服务器,获取资源信息,创建文件,并指定文件大小
[java]?view plainHYPERLINK /zhzhl202/article/details/7521377copy
length?=?config.getUrl().openConnection().getContentLength();??
RandomAccessFile?file?=?new?RandomAccessFile(config.getFile(),?rw);??
file.setLength(length);??
file.close();??
3)切分资源,为每个线程分配固定的下载区域,并将当前的下载加入到队列中
[java]?view plainHYPERLINK /zhzhl202/article/details/7521377copy
int?size?=?length?/?config.getNthread();??
for(int?i?=?0;?i??config.getNthread();?i++){??
????int?start?=?i?*?size;??
牋牋inint?len;??
牋牋t?if(i?==?config.getNthread()?-?1)??
牋牋牋牋?==?len?=?length?-?start;??
牋牋n?else?len?=?size;??
//并将当前的下载加入到下载队列中??
????addDownloadBlock(getDownloadBlock(start,?len));??
}??
3)启动线程进行下载
下载的步骤如下:
? ?1. 创建缓存,创建连接。设置获取资源数据的范围,创建文件,并设置写入位置
[java]?view plainHYPERLINK /zhzhl202/article/details/7521377copy
//创建缓存??
byte?[]?b;??
if(block.getLength()?
文档评论(0)