CN112286683A - 一种分片下载方法、装置及介质 - Google Patents
一种分片下载方法、装置及介质 Download PDFInfo
- Publication number
- CN112286683A CN112286683A CN202011180386.0A CN202011180386A CN112286683A CN 112286683 A CN112286683 A CN 112286683A CN 202011180386 A CN202011180386 A CN 202011180386A CN 112286683 A CN112286683 A CN 112286683A
- Authority
- CN
- China
- Prior art keywords
- fragment
- target
- thread
- downloaded
- downloading
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5027—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5027—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
- G06F9/505—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals considering the load
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/06—Protocols specially adapted for file transfer, e.g. file transfer protocol [FTP]
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Information Transfer Between Computers (AREA)
Abstract
本公开提供了一种分片下载方法、装置及介质,此方法包括:在使用一个以上线程下载目标文件的过程中,所述目标文件包括至少一个以上的分片,在所述目标文件的分片中不包括未开始下载的分片时,循环执行以下内容,直至满足终止条件:检测处于空闲状态的线程,从所述处于空闲状态的线程中确定至少一目标线程;从未下载完成的分片中选择出至少一目标分片,从所述至少一目标分片的未下载部分划分出至少一子分片;所述至少一子分片的数量等于所述目标线程的数量;为每个目标线程分配下载任务,不同的下载任务对应于选择出的不同的子分片。本公开中,充分线程的下载能力,使所有线程或者尽量多的线程处于工作状态,提升下载效率,提高下载速度。
Description
技术领域
本公开涉及无线网络数据处理技术领域,尤其涉及一种分片下载方法、装置及介质。
背景技术
从网络中下载一文件时,将此文件划分成多个分片,由一个或以一个以上线程进行分片下载。
在多线程下载的过程中,为每个线程分配需下载的分片,其中一个线程下载完为其分配的分片后,会为此线程再分配一个尚未下载的分片,从而达到下载线程复用的效果。
如何在此基础上进一步提高下载效率是需要解决的技术问题。
发明内容
为克服相关技术中存在的问题,本公开提供了一种分片下载方法、装置及介质。
根据本公开实施例的第一方面,提供一种分片下载方法,包括:
在使用一个以上线程下载目标文件的过程中,所述目标文件包括至少一个以上的分片,在所述目标文件的分片中不包括未开始下载的分片时,循环执行以下内容,直至满足终止条件:
检测处于空闲状态的线程,从所述处于空闲状态的线程中确定至少一目标线程;
从未下载完成的分片中选择出至少一目标分片,从所述至少一目标分片的未下载部分划分出至少一子分片;所述至少一子分片的数量等于所述目标线程的数量;
为每个目标线程分配下载任务,不同的下载任务对应于选择出的不同的子分片。
在一实施方式中,所述终止条件包括以下中的一种:
所述目标文件下载完成;
各个未下载完成的分片的未下载部分的容量小于设定容量。
在一实施方式中,所述方法还包括:
确定所述至少一目标分片对应的正在进行分片下载的线程,根据划分出的至少一子分片更新所述线程的下载任务。
在一实施方式中,所述从所述至少一目标分片的未下载部分划分出至少一子分片,包括:在所述目标分片是未进行过子分片划分的分片时,从所述目标分片中的未下载部分划分出至少一子片文件。
在一实施方式中,所述从所述至少一目标分片的未下载部分划分出至少一子分片,包括:对于所述至少一目标分片中已进行过子分片划分的目标分片,从所述目标分片中的子分片中选择出一未下载部分的容量最大的子分片,从选择出的子分片中划分新的子分片。
在一实施方式中,所述从所述处于空闲状态的线程中确定至少一目标线程,包括:
将所述处于空闲状态的线程作为目标线程。
在一实施方式中,所述从所述处于空闲状态的线程中确定至少一目标线程,包括:
从所述处于空闲状态的线程中根据选择条件选择至少一目标线程;
所述选择条件包括以下中的一种:
选择历史平均下载速度大于设定速度的线程作为目标线程;
确定用于下载所述目标文件的所有线程的历史平均下载速度的排序,从所述排序中下载速度值最大的一端开始选择连续的设定个数的历史平均下载速度,将选择出的各历史平均下载速度所对应的线程作为目标线程。
在一实施方式中,所述从未下载完成的分片中选择出至少一目标分片,包括以下中的一种:
确定各未下载完成的分片中未下载部分的容量的排序,从所述排序中容量值最大的一端开始选择连续的至少一容量,确定选择出的至少一容量对应的至少一目标分片;
确定各未下载完成的分片的下载完成剩余时长的排序,从所述排序中时长值最大的一端开始选择连续的至少一下载完成剩余时长,确定选择出的至少一下载完成剩余时长对应的至少一目标分片。
根据本公开实施例的第二方面,提供一种分片下载装置,包括:
触发模块,被配置为在使用一个以上线程下载目标文件的过程中,所述目标文件包括至少一个以上的分片,在所述目标文件的分片中不包括未开始下载的分片时,循环执行以下内容,直至满足终止条件:
所述循环模块,包括:
确定模块,被配置为检测处于空闲状态的线程,从所述处于空闲状态的线程中确定至少一目标线程;
选择模块,被配置为从未下载完成的分片中选择出至少一目标分片;
划分模块,被配置为从所述至少一目标分片的未下载部分划分出至少一子分片;所述至少一子分片的数量等于所述目标线程的数量;
分配模块,被配置为为每个目标线程分配下载任务,不同的下载任务对应于选择出的不同的子分片。
在一实施方式中,所述终止条件包括以下中的一种:
所述目标文件下载完成;
各个未下载完成的分片的未下载部分的容量小于设定容量。
在一实施方式中,所述循环模块,还包括:
更新模块,被配置为确定所述至少一目标分片对应的正在进行分片下载的线程,根据划分出的至少一子分片更新所述线程的下载任务。
在一实施方式中,所述划分模块,还被配置为使用以下方法从所述至少一目标分片的未下载部分划分出至少一子分片:
在所述目标分片是未进行过子分片划分的分片时,从所述目标分片中的未下载部分划分出至少一子片文件。
在一实施方式中,所述划分模块,还被配置为使用以下方法从所述至少一目标分片的未下载部分划分出至少一子分片:
对于所述至少一目标分片中已进行过子分片划分的目标分片,从所述目标分片中的子分片中选择出一未下载部分的容量最大的子分片,从选择出的子分片中划分新的子分片。
在一实施方式中,所述确定模块,还被配置为使用以下方法从所述处于空闲状态的线程中确定至少一目标线程:
将所述处于空闲状态的线程作为目标线程。
在一实施方式中,所述确定模块,还被配置为使用以下方法从所述处于空闲状态的线程中确定至少一目标线程:
从所述处于空闲状态的线程中根据选择条件选择至少一目标线程;
所述选择条件包括以下中的一种:
选择历史平均下载速度大于设定速度的线程作为目标线程;
确定用于下载所述目标文件的所有线程的历史平均下载速度的排序,从所述排序中下载速度值最大的一端开始选择连续的设定个数的历史平均下载速度,将选择出的各历史平均下载速度所对应的线程作为目标线程。
在一实施方式中,选择模块,被配置为使用以下中的一种从未下载完成的分片中选择出至少一目标分片:
确定各未下载完成的分片中未下载部分的容量的排序,从所述排序中容量值最大的一端开始选择连续的至少一容量,确定选择出的至少一容量对应的至少一目标分片;
确定各未下载完成的分片的下载完成剩余时长的排序,从所述排序中时长值最大的一端开始选择连续的至少一下载完成剩余时长,确定选择出的至少一下载完成剩余时长对应的至少一目标分片。
根据本公开实施例的第三方面,提供一种分片下载装置,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行所述存储器中的可执行指令以实现所述方法的步骤。
根据本公开实施例的第四方面,提供一种非临时性计算机可读存储介质,其上存储有可执行指令,该可执行指令被处理器执行时实现所述方法的步骤。
本公开的实施例提供的技术方案可以包括以下有益效果:在使用一个以上线程下载目标文件中一个以上分片的过程中,在所述目标文件的分片中不包括未开始下载的分片后,检测到存在处于空闲状态的线程时,从未下载完成的分片中的未下载部分划分出新的子分片,将划分出的子分片分配给处于空闲状态的线程下载,从而充分线程的下载能力,使所有线程或者尽量多的线程处于工作状态,提升下载效率,提高下载速度,提高用户使用体验。本实施例尤其适用于弱信号网络环境下,并且对于下载类的应用有重要实用意义。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理。
图1是根据一示例性实施例示出的一种分片下载方法的流程图;
图2是根据一示例性实施例示出的一种分片分配的示意图;
图3是根据一示例性实施例示出的一种分片分配的示意图;
图4是根据一示例性实施例示出的一种分片下载装置的结构图;
图5是根据一示例性实施例示出的一种分片下载装置的结构图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本公开相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本公开的一些方面相一致的装置和方法的例子。
在实际使用中,不同的线程的下载速度不同,对于同一文件的多个分片,使用不同下载速度的线程进行下载时,会出现高速线程对应的分片先下载完成,而低速线程的分片还未下载完成,此时高速线程处于空闲状态,等待低速线程下载完其对应的分片,此种情况下,浪费了高速线程的处理能力,尤其在低速线程的速度较低时,会导致后续下载时长较长,增大整个文件的下载时长,影响用户的下载使用体验。
本公开实施例中提供一种分片下载方法。参照图1,图1是根据一示例性实施例示出的一种分片下载方法的流程图。如图1所示,此方法包括:
步骤S11:在使用一个以上线程下载目标文件过程中,所述目标文件包括至少一个以上的分片,在所述目标文件的分片中不包括未开始下载的分片时,循环执行以下内容,直至满足终止条件:
步骤S12:检测处于空闲状态的线程,从所述处于空闲状态的线程中确定至少一目标线程;
步骤S13,从未下载完成的分片中选择出至少一目标分片,从所述至少一目标分片的未下载部分划分出至少一子分片;所述至少一子分片的数量等于所述目标线程的数量;
步骤S14,为每个目标线程分配下载任务,不同的下载任务对应于选择出的不同的子分片。
在一实施方式中,终止条件包括以下中的一种:
一,所述目标文件下载完成;
二,各个未下载完成的分片的未下载部分的容量小于设定容量。例如设定容量为1兆。此方式中,通过设置设定容量,可以防止无限划分的情况。
本实施例中,在使用一个以上线程下载目标文件中一个以上分片的过程中,在所述目标文件的分片中不包括未开始下载的分片后,检测到存在处于空闲状态的线程时,从未下载完成的分片中的未下载部分划分出新的子分片,将划分出的子分片分配给处于空闲状态的线程下载,从而充分线程的下载能力,使所有线程或者尽量多的线程处于工作状态,提升下载效率,提高下载速度,提高用户使用体验。本实施例尤其适用于弱信号网络环境下,并且对于下载类的应用有重要实用意义。
本公开实施例中提供一种分片下载方法,此方法包括图1所示的方法,并且:
步骤S13和步骤S14之间还包括步骤S13’:根据划分出的至少一子分片更新所述至少一目标分片对应的正在进行分片下载的线程的下载任务。具体为:确定所述至少一目标分片对应的正在进行分片下载的线程,根据划分出的至少一子分片更新所述线程的下载任务。
在一实施方式中,步骤S13中从所述至少一目标分片的未下载部分划分出至少一子分片,包括:在所述目标分片是未进行过子分片划分的分片时,从所述目标分片中的未下载部分划分出至少一子片文件。
例如:第一线程用于下载第一目标分片,第一目标分片的容量是100兆,第一线程已下载完成的部分的容量是40兆,剩余的未下载的容量是60兆。从未下载的部分划分出一个40兆的子分片,使目标线程下载划分出的40兆的子分片,更新第一线程的下载任务为此目标分片中除去子分片后的剩余的60兆的子分片。
在一实施方式中,步骤S13中从所述至少一目标分片的未下载部分划分出至少一子分片,包括:对于所述至少一目标分片中已进行过子分片划分的目标分片,从所述目标分片中的子分片中选择出一未下载部分的容量最大的子分片,从选择出的子分片中划分新的子分片。
例如:第一线程用于下载第一目标分片中第一子分片,第一子分片的容量是60兆,第一线程已下载完成的部分的容量是10兆,剩余的未下载的容量是50兆。从未下载的部分划分出一个30兆的子分片,使目标线程下载划分出的30兆的子分片,更新第一线程的下载任务为此第一子分片中除去子分片后的剩余的30兆的新的子分片。
在本实施例中,支持在子分片中再次划分子分片,为空闲的线程分配更小单位的待下载文件,从而得以充分利用线程的下载能力。
本公开实施例中提供一种分片下载方法,此方法包括图1所示的方法,并且:
步骤S12中从所述处于空闲状态的线程中确定至少一目标线程,包括:将所述处于空闲状态的线程作为目标线程。
本实施例中,在部分线程完成其自身的下载任务后,从未下载完成的目标分片中划分出新的分片给处于空闲状态的线程,使其重新进入工作状态,使所有线程均处于工作状态,充分利用所有线程的下载能力,提升下载效率,提高下载速度。
本公开实施例中提供一种分片下载方法,此方法包括图1所示的方法,并且:
步骤S12中从所述处于空闲状态的线程中确定至少一目标线程,包括:
从所述处于空闲状态的线程中根据选择条件选择至少一目标线程;
所述选择条件包括以下中的一种:
一,选择历史平均下载速度大于设定速度的线程作为目标线程;
二,确定用于下载所述目标文件的所有线程的历史平均下载速度的排序,从所述排序中下载速度值最大的一端开始选择连续的设定个数的历史平均下载速度,将选择出的各历史平均下载速度所对应的线程作为目标线程。
本实施例中,从处于空闲状态的线程中选择下载速度较大的线程作为目标线程,使用下载速度较大的目标线程重新进入工作状态,参与子分片下载,充分利用尽量多的线程的下载能力,提升下载效率,提高下载速度。
本公开实施例中提供一种分片下载方法,此方法包括图1所示的方法,并且:
步骤S13中从未下载完成的分片中选择出至少一目标分片,包括以下中的一种:
一,确定各未下载完成的分片中未下载部分的容量的排序,从所述排序中容量值最大的一端开始选择连续的至少一容量,确定选择出的至少一容量对应的至少一目标分片;
二,确定各未下载完成的分片的下载完成剩余时长的排序,从所述排序中时长值最大的一端开始选择连续的至少一下载完成剩余时长,确定选择出的至少一下载完成剩余时长对应的至少一目标分片。
本实施例中,从未下载部分的容量较大的目标分片中或者下载完成剩余时长较大的目标分片划分出子分片分配给目标线程,减少为目标线程分配任务的次数,提高处理效率。
本公开实施例中提供一种分片下载方法,此方法包括图1所示的方法,并且还包括:在所有未下载完成的分片的未下载部分的容量均小于设定容量,或者,所述未下载完成的分片对应的线程的下载速度均小于设定速度时,确定处于空闲状态的线程的历史平均下载速度大于所述设定速度后,暂停正在下载所述未下载完成的分片的线程,将此未下载完成的分片分配给所述处于空闲状态的线程进行下载。
本实施例中,为了防止无限划分并且尽量提高下载速率,停用此下载速度较小的线程,使用下载速度较高的处于空闲状态的线程进行下载,提高下载速率。
下面通过具体实施例进行详细说明。
具体实施例一
如图2中第一个图所示,将目标文件划分为3个分片,此3个分片包括:分片1,分片2和分片3。
由3个线程下载目标文件。此3个线程包括:第一线程、第二线程和第三线程。
为3个线程分配下载任务:
第一线程的下载任务对应的分片是分片1;
第二线程的下载任务对应的分片是分片2;
第三线程的下载任务对应的分片是分片3。
第一线程、第二线程和第三线程分别执行下载任务,均处于下载状态。
实时检测处于空闲状态的线程。
如图2中第二个图所示,第二线程下载分片2完成,第三线程下载分片3完成,第二线程和第三线程均从工作状态转换为空闲状态。第一线程未完成相应的下载任务,处于下载状态。
将第二线程和第三线程确定为目标线程。
确定未下载完成的分片为分片1。
如图2中第三个图所示,从分片1中未下载的部分划分出两个容量相同的子分片,分别称为分片1-1和分片1-2,为第二线程分配下载任务,此下载任务为下载子分片1-1;为第三线程分配下载任务,此下载任务为下载子分片1-2。更新第一线程的下载任务为新的子分片1-3,子分片1-3是分片1除去子分片1-1和子分片1-2之后的分片。
第一线程、第二线程和第三线程同时下载分片1。
所有子分片的未下载完成的部分的容量均小于设定容量,后续不再进行线程的下载任务重分配,直至目标文件中所有分片都下载完成。
具体实施例二
如图3中第一个图所示,将目标文件划分为4个分片,此4个分片包括:分片1,分片2,分片3和分片4。
由4个线程下载目标文件。此4个线程包括:第一线程、第二线程、第三线程和第四线程。
为4个线程分配下载任务:
第一线程的下载任务对应的分片是分片1;
第二线程的下载任务对应的分片是分片2;
第三线程的下载任务对应的分片是分片3;
第四线程的下载任务对应的分片是分片4。
第一线程、第二线程、第三线程和第四线程分别执行下载任务,均处于下载状态。
实时检测处于空闲状态的线程。
如图3中第二个图所示,第二线程下载分片2完成后,从工作状态转换为空闲状态。其它线程均未完成相应的下载任务,均处于下载状态。
将第二线程确定为目标线程。
从未下载完成的分片即分片1、分片3和分片4中选择出未下载部分的容量最大的分片即分片1。
如图2中第三个图所示,从分片1中未下载的部分划分出一个子分片称为分片1-1,为第二线程分配下载任务,此下载任务为下载子分片1-1。更新第一线程的下载任务为新的子分片1-2,子分片1-2是分片1除去子分片1-1之后的分片。
第一线程和第二线程同时下载分片1。
如图3中第四个图所示,第三线程下载分片3完成后,从下载状态转换为空闲状态。分片1和分片4均未下载完成,第一线程、第二线程和第四线程均处于下载状态。
将第三线程确定为目标线程。
从未下载完成的分片即分片1和分片4中选择出未下载部分的容量最大的分片即分片4。
如图3中第五个图所示,从分片1-1中未下载完成的部分划分出一个子分片称为子分片1-1-1,为第三线程分配下载任务,此下载任务为下载子分片1-1-1。更新第二线程的子分片为子分片1-1-2,此子分片1-1-2是分片1-1中除去子分片1-1-1之外的分片。
第一线程、第二线程和第三线程同时下载分片1,第四线程下载分片4。
在分片1完成下载后,从分片4中的未下载部分划分出3个子分片分别分配给第一线程、第二线程和第三线程进行下载,所有子分片的未下载完成的部分的容量均小于设定容量,后续不再进行线程的下载任务重分配,直至目标文件中所有分片都下载完成。
本公开实施例中提供一种分片下载装置。参照图4,图4是根据一示例性实施例示出的一种分片下载装置的结构图。如图4所示,此装置包括:
触发模块401,被配置为在使用一个以上线程下载目标文件的过程中,所述目标文件包括至少一个以上的分片,在所述目标文件的分片中不包括未开始下载的分片时,循环执行以下内容,直至满足终止条件:
所述循环模块,包括:
确定模块402,被配置为检测处于空闲状态的线程,从所述处于空闲状态的线程中确定至少一目标线程;
选择模块403,被配置为从未下载完成的分片中选择出至少一目标分片;
划分模块404,被配置为从所述至少一目标分片的未下载部分划分出至少一子分片;所述至少一子分片的数量等于所述目标线程的数量;
分配模块405,被配置为为每个目标线程分配下载任务,不同的下载任务对应于选择出的不同的子分片。
在一实施方式中,所述终止条件包括以下中的一种:
所述目标文件下载完成;
各个未下载完成的分片的未下载部分的容量小于设定容量。
本公开实施例中提供一种分片下载装置,此装置包括图4所示的装置,并且所述循环模块,还包括:
更新模块,被配置为确定所述至少一目标分片对应的正在进行分片下载的线程,根据划分出的至少一子分片更新所述线程的下载任务。
本公开实施例中提供一种分片下载装置,此装置包括图4所示的装置,并且:所述划分模块,还被配置为使用以下方法从所述至少一目标分片的未下载部分划分出至少一子分片:
在所述目标分片是未进行过子分片划分的分片时,从所述目标分片中的未下载部分划分出至少一子片文件。
所述划分模块,还被配置为使用以下方法从所述至少一目标分片的未下载部分划分出至少一子分片:对于所述至少一目标分片中已进行过子分片划分的目标分片,从所述目标分片中的子分片中选择出一未下载部分的容量最大的子分片,从选择出的子分片中划分新的子分片。
本公开实施例中提供一种分片下载装置,此装置包括图4所示的装置,并且:所述确定模块,还被配置为使用以下方法从所述处于空闲状态的线程中确定至少一目标线程:
将所述处于空闲状态的线程作为目标线程。
本公开实施例中提供一种分片下载装置,此装置包括图4所示的装置,并且:所述确定模块,还被配置为使用以下方法从所述处于空闲状态的线程中确定至少一目标线程:
从所述处于空闲状态的线程中根据选择条件选择至少一目标线程;
所述选择条件包括以下中的一种:
选择历史平均下载速度大于设定速度的线程作为目标线程;
确定用于下载所述目标文件的所有线程的历史平均下载速度的排序,从所述排序中下载速度值最大的一端开始选择连续的设定个数的历史平均下载速度,将选择出的各历史平均下载速度所对应的线程作为目标线程。
本公开实施例中提供一种分片下载装置,此装置包括图4所示的装置,并且:选择模块,被配置为使用以下中的一种从未下载完成的分片中选择出至少一目标分片:
确定各未下载完成的分片中未下载部分的容量的排序,从所述排序中容量值最大的一端开始选择连续的至少一容量,确定选择出的至少一容量对应的至少一目标分片;
确定各未下载完成的分片的下载完成剩余时长的排序,从所述排序中时长值最大的一端开始选择连续的至少一下载完成剩余时长,确定选择出的至少一下载完成剩余时长对应的至少一目标分片。
本公开实施例中提供一种分片下载装置,此装置包括图4所示的装置,并且:所述装置还包括:
调整模块,被配置为在所有未下载完成的分片的未下载部分的容量均小于设定容量,或者,所述未下载完成的分片对应的线程的下载速度均小于设定速度时,确定处于空闲状态的线程的历史平均下载速度大于所述设定速度后,暂停正在下载所述未下载完成的分片的线程,将此分片中未下载完成的部分分配给所述处于空闲状态的线程下载。
图5是根据一示例性实施例示出的一种分片下载装置500的框图。例如,装置500可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图5,装置500可以包括以下一个或多个组件:处理组件502,存储器504,电源组件506,多媒体组件508,音频组件510,输入/输出(I/O)的接口512,传感器组件514,以及通信组件516。
处理组件502通常控制装置500的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件502可以包括一个或多个处理器520来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件502可以包括一个或多个模块,便于处理组件502和其他组件之间的交互。例如,处理组件502可以包括多媒体模块,以方便多媒体组件508和处理组件502之间的交互。
存储器504被配置为存储各种类型的数据以支持在设备500的操作。这些数据的示例包括用于在装置500上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器504可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电源组件506为装置500的各种组件提供电力。电源组件506可以包括电源管理系统,一个或多个电源,及其他与为装置500生成、管理和分配电力相关联的组件。
多媒体组件508包括在所述装置500和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件508包括一个前置摄像头和/或后置摄像头。当设备500处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件510被配置为输出和/或输入音频信号。例如,音频组件510包括一个麦克风(MIC),当装置500处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器504或经由通信组件516发送。在一些实施例中,音频组件510还包括一个扬声器,用于输出音频信号。
I/O接口512为处理组件502和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件514包括一个或多个传感器,用于为装置500提供各个方面的状态评估。例如,传感器组件514可以检测到设备500的打开/关闭状态,组件的相对定位,例如所述组件为装置500的显示器和小键盘,传感器组件514还可以检测装置500或装置500一个组件的位置改变,用户与装置500接触的存在或不存在,装置500方位或加速/减速和装置500的温度变化。传感器组件514可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件514还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件514还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件516被配置为便于装置500和其他设备之间有线或无线方式的通信。装置500可以接入基于通信标准的无线网络,如WiFi,2G或3G,或它们的组合。在一个示例性实施例中,通信组件516经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信组件516还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,装置500可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器504,上述指令可由装置500的处理器520执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本公开的其它实施方案。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。
Claims (18)
1.一种分片下载方法,其特征在于,包括:
在使用一个以上线程下载目标文件的过程中,所述目标文件包括至少一个以上的分片,在所述目标文件的分片中不包括未开始下载的分片时,循环执行以下内容,直至满足终止条件:
检测处于空闲状态的线程,从所述处于空闲状态的线程中确定至少一目标线程;
从未下载完成的分片中选择出至少一目标分片,从所述至少一目标分片的未下载部分划分出至少一子分片;所述至少一子分片的数量等于所述目标线程的数量;
为每个目标线程分配下载任务,不同的下载任务对应于选择出的不同的子分片。
2.如权利要求1所述的分片下载方法,其特征在于,
所述终止条件包括以下中的一种:
所述目标文件下载完成;
各个未下载完成的分片的未下载部分的容量小于设定容量。
3.如权利要求1所述的分片下载方法,其特征在于,
所述方法还包括:
确定所述至少一目标分片对应的正在进行分片下载的线程,根据划分出的至少一子分片更新所述线程的下载任务。
4.如权利要求1、2或3所述的分片下载方法,其特征在于,
所述从所述至少一目标分片的未下载部分划分出至少一子分片,包括:
在所述目标分片是未进行过子分片划分的分片时,从所述目标分片中的未下载部分划分出至少一子片文件。
5.如权利要求1、2或3所述的分片下载方法,其特征在于,
对于所述至少一目标分片中已进行过子分片划分的目标分片,从所述目标分片中的子分片中选择出一未下载部分的容量最大的子分片,从选择出的子分片中划分新的子分片。
6.如权利要求1、2或3所述的分片下载方法,其特征在于,
所述从所述处于空闲状态的线程中确定至少一目标线程,包括:
将所述处于空闲状态的线程作为目标线程。
7.如权利要求1、2或3所述的分片下载方法,其特征在于,
所述从所述处于空闲状态的线程中确定至少一目标线程,包括:
从所述处于空闲状态的线程中根据选择条件选择至少一目标线程;
所述选择条件包括以下中的一种:
选择历史平均下载速度大于设定速度的线程作为目标线程;
确定用于下载所述目标文件的所有线程的历史平均下载速度的排序,从所述排序中下载速度值最大的一端开始选择连续的设定个数的历史平均下载速度,将选择出的各历史平均下载速度所对应的线程作为目标线程。
8.如权利要求1、2或3所述的分片下载方法,其特征在于,
所述从未下载完成的分片中选择出至少一目标分片,包括以下中的一种:
确定各未下载完成的分片中未下载部分的容量的排序,从所述排序中容量值最大的一端开始选择连续的至少一容量,确定选择出的至少一容量对应的至少一目标分片;
确定各未下载完成的分片的下载完成剩余时长的排序,从所述排序中时长值最大的一端开始选择连续的至少一下载完成剩余时长,确定选择出的至少一下载完成剩余时长对应的至少一目标分片。
9.一种分片下载装置,其特征在于,包括:
触发模块,被配置为在使用一个以上线程下载目标文件的过程中,所述目标文件包括至少一个以上的分片,在所述目标文件的分片中不包括未开始下载的分片时,循环执行以下内容,直至满足终止条件:
所述循环模块,包括:
确定模块,被配置为检测处于空闲状态的线程,从所述处于空闲状态的线程中确定至少一目标线程;
选择模块,被配置为从未下载完成的分片中选择出至少一目标分片;
划分模块,被配置为从所述至少一目标分片的未下载部分划分出至少一子分片;所述至少一子分片的数量等于所述目标线程的数量;
分配模块,被配置为为每个目标线程分配下载任务,不同的下载任务对应于选择出的不同的子分片。
10.如权利要求9所述的分片下载装置,其特征在于,
所述终止条件包括以下中的一种:
所述目标文件下载完成;
各个未下载完成的分片的未下载部分的容量小于设定容量。
11.如权利要求9所述的分片下载装置,其特征在于,
所述循环模块,还包括:
更新模块,被配置为确定所述至少一目标分片对应的正在进行分片下载的线程,根据划分出的至少一子分片更新所述线程的下载任务。
12.如权利要求9、10或11所述的分片下载装置,其特征在于,
所述划分模块,还被配置为使用以下方法从所述至少一目标分片的未下载部分划分出至少一子分片:
在所述目标分片是未进行过子分片划分的分片时,从所述目标分片中的未下载部分划分出至少一子片文件。
13.如权利要求9、10或11所述的分片下载装置,其特征在于,
所述划分模块,还被配置为使用以下方法从所述至少一目标分片的未下载部分划分出至少一子分片:
对于所述至少一目标分片中已进行过子分片划分的目标分片,从所述目标分片中的子分片中选择出一未下载部分的容量最大的子分片,从选择出的子分片中划分新的子分片。
14.如权利要求9、10或11所述的分片下载装置,其特征在于,
所述确定模块,还被配置为使用以下方法从所述处于空闲状态的线程中确定至少一目标线程:
将所述处于空闲状态的线程作为目标线程。
15.如权利要求9、10或11所述的分片下载装置,其特征在于,
所述确定模块,还被配置为使用以下方法从所述处于空闲状态的线程中确定至少一目标线程:
从所述处于空闲状态的线程中根据选择条件选择至少一目标线程;
所述选择条件包括以下中的一种:
选择历史平均下载速度大于设定速度的线程作为目标线程;
确定用于下载所述目标文件的所有线程的历史平均下载速度的排序,从所述排序中下载速度值最大的一端开始选择连续的设定个数的历史平均下载速度,将选择出的各历史平均下载速度所对应的线程作为目标线程。
16.如权利要求9、10或11所述的分片下载装置,其特征在于,
选择模块,被配置为使用以下中的一种从未下载完成的分片中选择出至少一目标分片:
确定各未下载完成的分片中未下载部分的容量的排序,从所述排序中容量值最大的一端开始选择连续的至少一容量,确定选择出的至少一容量对应的至少一目标分片;
确定各未下载完成的分片的下载完成剩余时长的排序,从所述排序中时长值最大的一端开始选择连续的至少一下载完成剩余时长,确定选择出的至少一下载完成剩余时长对应的至少一目标分片。
17.一种分片下载装置,其特征在于,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行所述存储器中的可执行指令以实现权利要求1至8中任一项所述方法的步骤。
18.一种非临时性计算机可读存储介质,其上存储有可执行指令,其特征在于,该可执行指令被处理器执行时实现权利要求1至8中任一项所述方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011180386.0A CN112286683A (zh) | 2020-10-29 | 2020-10-29 | 一种分片下载方法、装置及介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011180386.0A CN112286683A (zh) | 2020-10-29 | 2020-10-29 | 一种分片下载方法、装置及介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN112286683A true CN112286683A (zh) | 2021-01-29 |
Family
ID=74373190
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202011180386.0A Pending CN112286683A (zh) | 2020-10-29 | 2020-10-29 | 一种分片下载方法、装置及介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112286683A (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113342886A (zh) * | 2021-06-23 | 2021-09-03 | 杭州数梦工场科技有限公司 | 数据交换方法和装置 |
CN115576995A (zh) * | 2022-11-09 | 2023-01-06 | 广州海量数据库技术有限公司 | 一种基于OpenGauss数据库的流数据加载方法 |
CN116669097A (zh) * | 2022-08-26 | 2023-08-29 | 天翼数字生活科技有限公司 | 基于OKhttp的分片传输的方法和装置 |
-
2020
- 2020-10-29 CN CN202011180386.0A patent/CN112286683A/zh active Pending
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113342886A (zh) * | 2021-06-23 | 2021-09-03 | 杭州数梦工场科技有限公司 | 数据交换方法和装置 |
CN116669097A (zh) * | 2022-08-26 | 2023-08-29 | 天翼数字生活科技有限公司 | 基于OKhttp的分片传输的方法和装置 |
CN115576995A (zh) * | 2022-11-09 | 2023-01-06 | 广州海量数据库技术有限公司 | 一种基于OpenGauss数据库的流数据加载方法 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN105955765B (zh) | 应用预加载方法及装置 | |
CN112286683A (zh) | 一种分片下载方法、装置及介质 | |
CN111404836B (zh) | 数据传输控制方法、装置、控制中心、服务器及介质 | |
KR20160042398A (ko) | 백그라운드 애플리케이션을 제어하기 위한 방법 및 장치 | |
CN109254849B (zh) | 应用程序的运行方法及装置 | |
JP2021531554A (ja) | 画像処理方法及び装置、電子機器並びに記憶媒体 | |
EP3046212A1 (en) | Method and apparatus for controlling charging of terminal device | |
EP3239827A1 (en) | Method and apparatus for adjusting playing progress of media file | |
CN113032030A (zh) | 相机启动方法、装置、终端设备和存储介质 | |
CN105912204B (zh) | 启动应用界面的方法及装置 | |
EP3668171A1 (en) | Data transmission method, device and computer readable storage medium | |
CN109062625B (zh) | 应用程序加载的方法、装置及可读存储介质 | |
CN108037987B (zh) | 应用程序控制方法、装置、存储介质 | |
CN108958911B (zh) | 进程的控制方法及装置 | |
CN108446178A (zh) | 优化卡顿的方法及装置 | |
CN107371222B (zh) | 虚拟卡禁用方法及装置 | |
CN106357558B (zh) | 带宽分配方法及装置 | |
CN108886461B (zh) | 数据传输方法及装置 | |
CN112307229A (zh) | 数据处理方法及装置、电子设备、计算机可读存储介质 | |
CN110704197B (zh) | 处理内存访问开销的方法、装置及介质 | |
CN112416580A (zh) | 确定应用运行时最佳资源配置方式的方法、装置及介质 | |
CN116089025A (zh) | 处理器频率控制方法、装置及存储介质 | |
CN111176841B (zh) | 一种图形处理器资源的分配方法、装置、电子设备及存储介质 | |
CN112383638B (zh) | 一种分片下载方法、装置及介质 | |
CN111314232A (zh) | 应用加速方法、装置及存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |