java多线程下载的问题请教。
想了好久都想不通。书里面是说每个线程负责下载的文件是intcurrentPartSize=fileSize/threadNum+1;其中fileSize是文件的总大小,t...
想了好久都想不通。书里面是说每个线程负责下载的文件是 int currentPartSize = fileSize/threadNum + 1; 其中fileSize是文件的总大小,threadNum是线程数目,currentPartSize是每个线程负责下载的文件大小。 我的疑惑是为什么后面要一个加1。想了一整个下午到现在都还是不懂。 希望懂的高手帮我解释下。。谢谢
展开
3个回答
展开全部
你书上的code和http://www.cnblogs.com/wanghui390/p/4046575.html 这个网址上的一样么?
如果一样的话,那么我觉得这么做的目的应该是:
fileSize/threadNum 的结果是四舍五入之后的结果,如果是舍去了一部分,那么按照这个网址上的code到最后就会有一点没有下载。所以它另每个filtePart的大小都增大1,并且在DownThread里面加入了另外一个条件:
length < currentPartSize && (hasRead = inStream.read(buffer)) > 0
就可以保证在文件的末尾,停止读操作。
如果一样的话,那么我觉得这么做的目的应该是:
fileSize/threadNum 的结果是四舍五入之后的结果,如果是舍去了一部分,那么按照这个网址上的code到最后就会有一点没有下载。所以它另每个filtePart的大小都增大1,并且在DownThread里面加入了另外一个条件:
length < currentPartSize && (hasRead = inStream.read(buffer)) > 0
就可以保证在文件的末尾,停止读操作。
展开全部
说实话我没明白你什么意思,不过我觉得没啥好疑惑的,多线程下载主要是多个线程分区域下载文件,下载完成在合并,不一定非要这样,你自己看着写,只要文件中间没有断掉的数据就ok了,比如说一共10k的东西,共分成4个线程下载,1+2+3+4;2+2+3+3,。。。。都是可以的。至于分配的过程,我觉得不用太过纠结
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
假设fileSize为13threadNum为4 ,13/4=3;则文件分片结果为0-3,3-6,6-9,9-12.不能全覆盖。
如果加1文件分片结果为
0-4,4-8,8-12,12-16可以实现全覆盖。
因为13/4是有余数的,如果不+1后边的余数没有计算在内(可能)会导致长度丢失。
如果加1文件分片结果为
0-4,4-8,8-12,12-16可以实现全覆盖。
因为13/4是有余数的,如果不+1后边的余数没有计算在内(可能)会导致长度丢失。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询