CN116074305A - 应用下载安装方法、应用老化方法及电子设备 - Google Patents
应用下载安装方法、应用老化方法及电子设备 Download PDFInfo
- Publication number
- CN116074305A CN116074305A CN202111280483.1A CN202111280483A CN116074305A CN 116074305 A CN116074305 A CN 116074305A CN 202111280483 A CN202111280483 A CN 202111280483A CN 116074305 A CN116074305 A CN 116074305A
- Authority
- CN
- China
- Prior art keywords
- sub
- electronic device
- packet
- application
- download
- 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
- G06F8/00—Arrangements for software engineering
- G06F8/60—Software deployment
- G06F8/61—Installation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
- H04L47/43—Assembling or disassembling of packets, e.g. segmentation and reassembly [SAR]
-
- 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]
Abstract
本申请适用于终端技术领域,尤其涉及应用下载安装方法、应用老化方法及电子设备。该应用下载安装方法中,第一应用至少包括第一部分和第二部分,第一部分包括第一子包,第二部分包括第二子包。当第一电子设备检测到下载第一应用的触发事件时,第一电子设备可以从第二设备获取第一子包,并从第三设备获取所第二子包,以根据第一部分和第二部分,安装第一应用。其中,第二设备与第三设备不同,以通过从不同设备分布式获取第一应用的不同子包,减少第一电子设备下载安装第一应用的时间,提高下载安装第一应用的速度,提升用户体验。
Description
技术领域
本申请属于终端技术领域,尤其涉及应用下载安装方法、应用老化方法、电子设备及计算机可读存储介质。
背景技术
随着电子设备和互联网技术的发展,电子设备的功能越来越强大,极大地丰富、便利了人们的日常生活。其中,电子设备的强大功能依赖于电子设备中下载的应用。目前,电子设备主要是从云端下载安装包来进行应用的安装使用。而由于受网络带宽和网络传输速率的影响,从云端下载安装包的方式,存在下载速度较慢的问题。
发明内容
本申请实施例提供了一种应用下载安装方法、应用老化方法、电子设备及计算机可读存储介质,可以解决现有技术中应用的下载速度较慢的问题。
第一方面,本申请实施例提供了一种应用下载安装方法,应用于第一电子设备,所述方法可以包括:
所述第一电子设备检测到下载第一应用的触发事件,所述第一应用至少包括第一部分和第二部分,所述第一部分包括第一子包,所述第二部分包括第二子包;
所述第一电子设备从第二设备获取所述第一子包,并从第三设备获取所述第二子包;所述第二设备与所述第三设备不同;
所述第一电子设备根据所述第一部分和所述第二部分,安装所述第一应用。
在上述的应用下载安装方法中,可以将第一应用的安装包拆分成第一部分和第二部分,第一部分可以包括第一子包,第二部分可以包括第二子包。当第一电子设备检测到下载第一应用的触发事件时,第一电子设备可以从第二设备获取第一子包,并可以同时从第三设备获取第二子包,以通过从不同的设备分布式获取第一应用的不同子包,可以减少第一电子设备下载安装第一应用的时间,提高第一电子设备下载安装第一应用的速度,从而提升用户体验。
其中,第一应用可以为任一应用。示例性的,第一应用可以为特性能力(featureability,FA),触发事件可以为对未安装的FA的点击或触摸操作等。例如当用户打开第一电子设备的服务中心,并点击服务中心的某一个未安装的FA时,第一电子设备可以将该FA确定为第一应用,并可以确定检测到下载该FA的触发事件。或者,第一应用可以为应用市场中某一个未安装的应用,触发事件可以为对该应用对应的安装或下载按钮的点击或触摸操作等。例如当用户打开第一电子设备中的应用市场,并点击短信息应用对应的安装或者下载按钮时,第一电子设备可以将短信息应用确定为第一应用,并可以确定检测到下载短信息应用的触发事件。
可以理解的是,第二设备可以为用户的第二电子设备,第三设备可以为用户的第三电子设备或服务器。也就是说,第一电子设备可以从第二电子设备获取第一子包,并从第三电子设备获取第二子包;或者,第一电子设备可以从第二电子设备获取第一子包,并从服务器获取第二子包。
示例性的,第一电子设备获取的第一子包可以是第二电子设备中存储的;或者,可以是第二电子设备获取的,例如可以是第二电子设备从服务器中获取的,或者可以是第二电子设备从存储有第一子包的其他电子设备中获取的。也就是说,当第二设备为用户的第二电子设备时,若第二电子设备中存储有第一子包,第一电子设备可以获取第二电子设备中存储的第一子包;若第二电子设备中未存储第一子包,第一电子设备可以向第二电子设备发送获取请求,请求第二电子设备从服务器或者从其他存储有第一子包的电子设备中获取第一子包,并将获取的第一子包发送给第一电子设备。
示例性的,当第三设备为用户的第三电子设备时,第一电子设备获取的第二子包可以是第三电子设备中存储的;或者,可以是第三电子设备获取的,例如可以是第三电子设备从服务器中获取的,或者可以是第三电子设备从存储有第二子包的其他电子设备中获取的。其中,其他电子设备也可以为用户的第二电子设备。
在一种可能的实现方式中,第一部分还可以包括第三子包,第一电子设备可以从第四设备获取第三子包,第四设备为用户的第四电子设备或服务器。其中,第四电子设备与第二电子设备可以为同一电子设备。或者,第四电子设备与第三电子设备可以为同一电子设备。当然,第四电子设备也可以为除第二电子设备和第三电子设备以外的电子设备。
在另一种可能的实现方式中,第二部分还可以包括第四子包,第一电子设备可以从第五设备获取第四子包。其中,第五设备可以为用户的第五电子设备或服务器。应理解,第五电子设备与第二电子设备可以为同一电子设备,或者第五电子设备与第三电子设备可以为同一电子设备,或者第五电子设备与第四电子设备可以为同一电子设备。当然,第五电子设备也可以为除第二电子设备、第三电子设备和第四电子设备以外的电子设备。
可以理解的是,第一部分是第一应用的基础部分;第二部分为特性部分,第二部分与第一电子设备的属性相关;或者,第一部分是特性部分,第二部分是基础部分。
在一种可能的实现方式中,在所述第一电子设备从第二设备获取所述第一子包,并从第三设备获取所述第二子包之前,所述方法还可以包括:
所述第一电子设备确定下载所述第一子包的第一下载时间,以及下载所述第二子包的第二下载时间;
所述第一电子设备根据所述第一下载时间和所述第二下载时间确定下载策略,所述下载策略包括:所述第一电子设备从第二设备获取所述第一子包,并从第三设备获取所述第二子包。
在该实现方式提供的应用下载安装方法中,第一电子设备可以根据下载第一子包的第一下载时间和下载第二子包的第二下载时间确定下载策略,以根据下载时间来确定第二设备和第三设备,确保第一电子设备获取第一应用的时间较短,提高第一电子设备的下载速度,提升用户体验。
应理解,第一子包的第一下载时间可以为第一电子设备从任一存储有第一子包的第六设备中获取第一子包的时间,或者可以为用户的某一电子设备从任一存储有第一子包的第六设备中下载第一子包的时间与该电子设备将所下载的第一子包传输给第一电子设备的时间之和。类似的,第二子包的第二下载时间可以为第一电子设备从任一存储有第二子包的设备中获取第二子包的时间,或者可以为用户的某一电子设备从任一存储有第二子包的设备中下载第二子包的时间与该电子设备将所下载的第二子包传输给第一电子设备的时间之和。
在一种可能的实现方式中,第一电子设备可以根据第一下载时间与第二下载时间之和最短来确定下载策略,使得第一电子设备获取第一应用的时间最短,提高应用的下载速度,提升用户体验。
在另一种可能的实现方式中,第一电子设备也可以获取第一下载时间和第二下载时间之和小于或等于预设时间阈值的下载策略,并从这些下载策略中确定最终的目标下载策略。在一个示例中,第一电子设备可以根据这些下载策略所对应的设备的使用情况和/或设备性能来确定目标下载策略。在另一个示例中,第一电子设备可以根据用户的选择操作来确定目标下载策略,即用户可以从这些下载策略中自行选择目标下载策略。其中,预设时间阈值可以由第一电子设备默认设置,也可以由用户自定义设置,例如用户可以根据自身所能接受的最大下载时间来设置预设时间阈值。
示例性的,所述第一电子设备确定下载所述第一子包的第一下载时间,可以包括:
所述第一电子设备获取所述第一子包的大小和所述第一子包对应的第一速度,所述第一子包对应的第一速度包括所述第一电子设备从存储有所述第一子包的第六设备下载所述第一子包的速度,或者包括第七设备下载所述第一子包的速度和所述第七设备将所述第一子包传输给所述第一电子设备的速度;
所述第一电子设备根据所述第一子包的大小和所述第一速度确定下载所述第一子包的第一下载时间。
应理解,当第一子包的第一下载时间为第一电子设备从任一存储有第一子包的第六设备中获取第一子包的时间时,第一子包对应的第一速度可以为第一电子设备从第六设备下载第一子包的速度。假设,存储有第一子包的第六设备包括多个,第一电子设备从第j个第六设备下载第一子包时,需经过时间tj,delay1达到稳定速度vj,max1(即第一速度),那么第一子包对应的第j个第一下载时间(即第一电子设备从第j个第六设备下载第一子包的时间)Tj1=tj,delay1+max(volume1-volume1’,0)/vj,max1,volume1为第一子包的大小,volume1’为在时间tj,delay1内,第一电子设备从第六设备下载的子包大小。
类似的,当第一子包的第一下载时间为第七设备从任一存储有第一子包的第六设备中下载第一子包的时间与第七设备将所下载的第一子包传输给第一电子设备的时间之和时,第一子包对应的第一速度可以包括第七设备从第六设备中下载第一子包的速度和第七设备将所下载的第一子包传输给第一电子设备的速度。此时,第一电子设备可以根据第七设备从第六设备中下载第一子包的速度与第一子包的大小,确定第七设备从第六设备中下载第一子包的时间,并可以根据第七设备将第一子包传输给第一电子设备的速度和第一子包的大小,确定第七设备将第一子包传输给第一电子设备的时间。其中,第七设备可以为用户的电子设备。时间的具体确定方式可以参照前述Tj1的确定方式。
在一种可能的实现方式中,在所述第一电子设备根据所述第一部分和所述第二部分,安装所述第一应用之后,所述方法还可以包括:
所述第一电子设备确定下载所述第一子包的第三下载时间和下载所述第二子包的第四下载时间;
所述第一电子设备根据所述第三下载时间和所述第四下载时间确定待老化的目标子包,并对所述目标子包进行老化,所述目标子包为所述第一子包,或者所述目标子包为所述第二子包,所述对所述目标子包进行老化包括删除所述目标子包或者卸载所述目标子包。
应理解,第三下载时间和第四下载时间的获取方式可以与前述第一下载时间和第二下载时间的获取方式相同。示例性的,第一电子设备也可以直接将第一下载时间作为第三下载时间,和/或将第二下载时间作为第四下载时间。例如,在第一电子设备下载安装第一应用之后,若存储第一子包的设备没有发生改变,第一电子设备可以直接将第一下载时间确定为第二下载时间,以减少下载时间的确定过程,提升老化效率。类似的,在第一电子设备下载安装第一应用之后,若存储第二子包的设备没有发生改变,第一电子设备可以直接将第二下载时间确定为第四下载时间,以减少下载时间的确定过程。
示例性的,当所述目标子包为所述第一子包时,所述第一电子设备对所述目标子包进行老化,可以包括:
所述第一电子设备对所述第一子包进行老化,并保留所述第二子包;
当所述目标子包为所述第二子包时,所述第一电子设备对所述目标子包进行老化,可以包括:
所述第一电子设备对所述第二子包进行老化,并保留所述第一子包。
在该实现方式提供的应用下载安装方法中,在第一电子设备需要对已下载安装的第一应用进行老化时,第一电子设备可以确定再次下载第一应用的各个子包的时间,并可以根据各个子包分别对应的下载时间对第一应用进行老化,以保留第一应用的部分子包,从而使得在下一次需要使用第一应用时,第一电子设备仅需要下载第一应用的部分子包,而不需要下载第一应用的整个安装包,可以减少第一应用的下载时间,提高再次启动第一应用的速度,提升用户体验。
示例性的,第一电子设备可以保留下载时间最长的子包,并可以将第一应用的其他子包进行老化,即可以将下载速度较慢的部分子包进行保留,使得再次启动第一应用时,可以减少第一应用的下载时间。应理解,对目标子包进行老化可以是指卸载目标子包,也可以是指删除目标子包。
第二方面,本申请实施例提供了一种应用老化方法,应用于第一电子设备,所述方法可以包括:
所述第一电子设备确定第一应用,所述第一应用包括第一子包和第二子包;
所述第一电子设备对所述第一子包和所述第二子包进行不同的处理,所述第一电子设备对所述第一子包和所述第二子包进行不同的处理包括:所述第一电子设备对所述第一子包进行老化,并保留所述第二子包;或者,所述第一电子设备在第一时间对所述第一子包进行老化,并在第二时间对所述第二子包进行老化;所述第一电子设备对所述第一子包进行老化包括所述第一电子设备删除所述第一子包或者卸载所述第一子包。
在一种可能的实现方式中,所述第一电子设备对所述第一子包和所述第二子包进行不同的处理,所述方法还可以包括:
所述第一电子设备获取第一子包的第一下载时间,以及获取第二子包的第二下载时间;
所述第一电子设备根据所述第一下载时间和所述第二下载时间确定待老化的目标子包,并对所述目标子包进行老化,所述目标子包为所述第一子包,或者所述目标子包为所述第二子包。
示例性的,当所述目标子包为所述第一子包时,所述第一电子设备对所述目标子包进行老化,可以包括:
所述第一电子设备对所述第一子包进行老化,并保留所述第二子包;
当所述目标子包为所述第二子包时,所述第一电子设备对所述目标子包进行老化,可以包括:
所述第一电子设备对所述第二子包进行老化,并保留所述第一子包。
在上述的应用老化方法中,可以将应用的安装包拆分成第一子包和第二子包。当第一电子设备需要对已下载安装的应用进行老化时,第一电子设备可以确定再次下载该应用的各个子包的时间,并可以根据各个子包分别对应的下载时间对该应用进行老化,以保留该应用的部分子包,从而使得在下一次需要使用该应用时,第一电子设备仅需要下载该应用的部分子包,而不需要下载该应用的整个安装包,可以减少应用的下载时间,提高再次启动应用的速度,提升用户体验。
示例性的,第一电子设备可以保留下载时间最长的子包,并可以将该应用的其他子包进行老化,即将下载速度较慢的部分子包进行保留,使得再次启动该应用时,可以减少该应用的下载时间。
可以理解的是,所述第一电子设备确定第一应用,可以包括:
所述第一电子设备获取第二应用的第一时长,所述第一时长为所述第二应用未被使用的连续时长,所述第二应用为所述第一电子设备中的任一应用;
当所述第一时长大于或等于预设时长阈值时,所述第一电子设备确定所述第二应用为所述第一应用。
示例性的,所述第一电子设备获取第一子包的第一下载时间,可以包括:
所述第一电子设备获取所述第一子包的大小和所述第一子包对应的第一速度,所述第一子包对应的第一速度包括所述第一电子设备从存储有所述第一子包的第二设备下载所述第一子包的速度,或者包括第三设备下载所述第一子包的速度和所述第三设备将所述第一子包传输给所述第一电子设备的速度;
所述第一电子设备根据所述第一子包的大小和所述第一速度确定所述第一子包的第一下载时间。
第三方面,本申请实施例提供了一种应用下载安装装置,应用于第一电子设备,所述装置可以包括:
触发事件检测模块,用于检测到下载第一应用的触发事件,所述第一应用至少包括第一部分和第二部分,所述第一部分包括第一子包,所述第二部分包括第二子包;
第一子包获取模块,用于从第二设备获取所述第一子包,并从第三设备获取所述第二子包;所述第二设备与所述第三设备不同;
应用安装模块,用于根据所述第一部分和所述第二部分,安装所述第一应用。
示例性的,所述第二设备为用户的第二电子设备,所述第三设备为用户的第三电子设备或服务器。
在一种可能的实现方式中,所述第一电子设备获取的第一子包是所述第二电子设备中存储的,或者,所述第一电子设备获取的第一子包是所述第二电子设备获取的。
在另一种可能的实现方式中,当所述第三设备为用户的第三电子设备时,所述第一电子设备获取的第二子包是所述第三电子设备中存储的,或者,所述第一电子设备获取的第二子包是所述第三电子设备获取的。
示例性的,所述第一部分还包括第三子包,所述装置还可以包括:
第三子包获取模块,用于从第四设备获取所述第三子包,所述第四设备为用户的第四电子设备或服务器。
示例性的,所述第二部分还包括第四子包,所述装置还可以包括:
第四子包获取模块,用于从第五设备获取所述第四子包。
可以理解的是,所述第一部分是所述第一应用的基础部分;所述第二部分为特性部分,所述第二部分与所述第一电子设备的属性相关;或者,所述第一部分是特性部分,第二部分是基础部分。
在一种可能的实现方式中,所述装置还可以包括:
第一下载时间确定模块,用于确定下载所述第一子包的第一下载时间,以及下载所述第二子包的第二下载时间;
下载策略确定模块,用于根据所述第一下载时间和所述第二下载时间确定下载策略,所述下载策略包括:所述第一电子设备从第二设备获取所述第一子包,并从第三设备获取所述第二子包。
示例性的,所述第一下载时间确定模块,可以包括:
第一速度获取单元,用于获取所述第一子包的大小和所述第一子包对应的第一速度,所述第一子包对应的第一速度包括所述第一电子设备从存储有所述第一子包的第六设备下载所述第一子包的速度,或者包括第七设备下载所述第一子包的速度和所述第七设备将所述第一子包传输给所述第一电子设备的速度;
第一下载时间确定单元,用于根据所述第一子包的大小和所述第一速度确定下载所述第一子包的第一下载时间
在另一种可能的实现方式中,所述装置还可以包括:
第三下载时间确定模块,用于确定下载所述第一子包的第三下载时间和下载所述第二子包的第四下载时间;
目标子包老化模块,用于根据所述第三下载时间和所述第四下载时间确定待老化的目标子包,并对所述目标子包进行老化,所述目标子包为所述第一子包,或者所述目标子包为所述第二子包,所述对所述目标子包进行老化包括删除所述目标子包或者卸载所述目标子包。
示例性的,当所述目标子包为所述第一子包时,所述目标子包老化模块,具体用于对所述第一子包进行老化,并保留所述第二子包;
当所述目标子包为所述第二子包时,所述目标子包老化模块,具体用于对所述第二子包进行老化,并保留所述第一子包。
第四方面,本申请实施例提供了一种应用老化装置,应用于第一电子设备,所述装置可以包括:
第一应用确定模块,用于确定第一应用,所述第一应用包括第一子包和第二子包;
子包处理模块,用于对所述第一子包和所述第二子包进行不同的处理,所述第一电子设备对所述第一子包和所述第二子包进行不同的处理包括:所述第一电子设备对所述第一子包进行老化,并保留所述第二子包;或者,所述第一电子设备在第一时间对所述第一子包进行老化,并在第二时间对所述第二子包进行老化;所述第一电子设备对所述第一子包进行老化包括所述第一电子设备删除所述第一子包或者卸载所述第一子包。
在一种可能的实现方式中,所述子包处理模块,可以包括:
下载时间获取单元,用于获取第一子包的第一下载时间,以及获取第二子包的第二下载时间;
目标子包老化单元,用于根据所述第一下载时间和所述第二下载时间确定待老化的目标子包,并对所述目标子包进行老化,所述目标子包为所述第一子包,或者所述目标子包为所述第二子包。
示例性的,当所述目标子包为所述第一子包时,所述目标子包老化单元,具体用于对所述第一子包进行老化,并保留所述第二子包;
当所述目标子包为所述第二子包时,所述目标子包老化单元,具体用于对所述第二子包进行老化,并保留所述第一子包。
在一种可能的实现方式中,所述第一应用确定模块,可以包括:
时长获取单元,用于获取第二应用的第一时长,所述第一时长为所述第二应用未被使用的连续时长,所述第二应用为所述第一电子设备中的任一应用;
第一应用确定单元,用于当所述第一时长大于或等于预设时长阈值时,所述第一电子设备确定所述第二应用为所述第一应用。
示例性的,所述下载时间获取单元,可以包括:
第一速度确定分单元,用于获取所述第一子包的大小和所述第一子包对应的第一速度,所述第一子包对应的第一速度包括所述第一电子设备从存储有所述第一子包的第二设备下载所述第一子包的速度,或者包括第三设备下载所述第一子包的速度和所述第三设备将所述第一子包传输给所述第一电子设备的速度;
下载时间确定分单元,用于根据所述第一子包的大小和所述第一速度确定所述第一子包的第一下载时间。
第五方面,本申请实施例提供了一种电子设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时,使所述电子设备实现上述第一方面中任一项所述的应用下载安装方法,或实现上述第二方面中任一项所述的应用老化方法。
第六方面,本申请实施例提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被计算机执行时,使所述计算机实现上述第一方面中任一项所述的应用下载安装方法,或实现上述第二方面中任一项所述的应用老化方法。
第七方面,本申请实施例提供了一种计算机程序产品,当计算机程序产品在电子设备上运行时,使得电子设备执行上述第一方面中任一项所述的应用下载安装方法,或者执行上述第二方面中任一项所述的应用老化方法。
可以理解的是,上述第三方面的有益效果可以参见上述第一方面中的相关描述,上述第四方面的有益效果可以参见上述第二方面中的相关描述,上述第五方面至第七方面的有益效果可以参见上述第一方面或第二方面中的相关描述,在此不再赘述。
附图说明
图1是本申请一实施例提供的应用下载安装方法所适用于的电子设备的结构示意图;
图2是本申请一实施例提供的应用下载安装方法所适用于的软件架构示意图;
图3是本申请实施例一提供的应用下载安装方法所应用的系统结构图;
图4和图5是本申请实施例一提供的应用场景示意图一;
图6是本申请实施例一提供的应用场景示意图二;
图7是本申请实施例一提供的应用场景示意图三;
图8是本申请实施例一提供的应用场景示意图四;
图9是本申请实施例一提供的应用下载安装方法的流程示意图;
图10是本申请实施例二提供的应用老化方法的应用场景示意图。
具体实施方式
应当理解,当在本申请说明书和所附权利要求书中使用时,术语“包括”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
还应当理解,在本申请说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
如在本申请说明书和所附权利要求书中所使用的那样,术语“如果”可以依据上下文被解释为“当...时”或“一旦”或“响应于确定”或“响应于检测到”。类似地,短语“如果确定”或“如果检测到[所描述条件或事件]”可以依据上下文被解释为意指“一旦确定”或“响应于确定”或“一旦检测到[所描述条件或事件]”或“响应于检测到[所描述条件或事件]”。
另外,在本申请说明书和所附权利要求书的描述中,术语“第一”、“第二”、“第三”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
在本申请说明书中描述的参考“一个实施例”或“一些实施例”等意味着在本申请的一个或多个实施例中包括结合该实施例描述的特定特征、结构或特点。由此,在本说明书中的不同之处出现的语句“在一个实施例中”、“在一些实施例中”、“在其他一些实施例中”、“在另外一些实施例中”等不是必然都参考相同的实施例,而是意味着“一个或多个但不是所有的实施例”,除非是以其他方式另外特别强调。术语“包括”、“包含”、“具有”及它们的变形都意味着“包括但不限于”,除非是以其他方式另外特别强调。
此外,本申请实施例中提到的“多个”应当被解释为两个或两个以上。
本申请实施例中提供的应用下载安装方法和应用老化方法中所涉及到的步骤仅仅作为示例,并非所有的步骤均是必须执行的步骤,或者并非各个信息或消息中的内容均是必选的,在使用过程中可以根据需要酌情增加或减少。本申请实施例中同一个步骤或者具有相同功能的步骤或者消息在不同实施例之间可以互相参考借鉴。
本申请实施例描述的业务场景是为了更加清楚的说明本申请实施例的技术方案,并不构成对于本申请实施例提供的技术方案的限定,本领域普通技术人员可知,随着网络架构的演变和新业务场景的出现,本申请实施例提供的技术方案对于类似的技术问题,同样适用。
随着电子设备和互联网技术的发展,手机、电脑、平板电脑、智慧大屏、可穿戴设备等电子设备成为了人们日常生活中必不可少的部分,电子设备的功能也越来越强大,极大地丰富、便利了人们的日常生活。其中,电子设备的强大功能依赖于电子设备中下载的应用。因此,如何快速下载安装应用成为本领域关注的重点。目前,电子设备主要是从云端下载应用的安装包来进行应用的安装使用。而由于受网络带宽和网络传输速率的影响,从云端下载安装包的方式,存在下载速度较慢的问题。
另外,为降低电子设备的资源占用,提高电子设备的处理性能,电子设备需要对电子设备中的应用进行老化处理。其中,老化处理是指对应用进行删除或者卸载处理。目前,在确定应用达到预设老化条件(例如应用长时间未被使用)时,电子设备即对该应用的整个安装包进行老化处理,即删除或卸载该应用的全部安装包。这种老化处理的方式,导致用户在下一次想要使用该应用时,需要重新下载该应用的全部安装包,极大地降低了应用再次启动的速度,降低了用户体验。
为解决上述问题,本申请实施例提供了一种应用下载安装方法,该方法将应用的安装包拆分成多个子包,云端和已下载该应用的电子设备可以存储有该应用的子包。当第一电子设备检测到下载该应用的触发事件时,第一电子设备可以同时从第二设备和第三设备下载该应用的部分子包,以减少第一电子设备下载该应用的安装包的时间,提高第一电子设备下载应用的速度,提升用户体验。
另外,本申请实施例还提供了一种应用老化方法,该方法将应用的安装包拆分成多个子包。在第一电子设备需要对应用进行老化时,第一电子设备可以确定再次下载该应用的各个子包的时间,并根据各个子包的下载时间对该应用进行老化,以保留该应用的部分子包,使得在下一次需要使用该应用时,第一电子设备仅需要下载该应用的部分子包,而不需要下载该应用的整个安装包,可以减少应用的下载时间,提高应用再次启动的速度,提升用户体验。
本申请实施例提供的应用下载安装方法和应用老化方法可以应用于电子设备,电子设备可以为手机、平板电脑、可穿戴设备(如智能手表、智能眼镜、智能耳机等)、智慧大屏、车载设备、智能音箱、增强现实(augmented reality,AR)/虚拟现实(virtual reality,VR)设备、笔记本电脑、超级移动个人计算机(ultra-mobile personal computer,UMPC)、上网本、个人数字助理(personal digital assistant,PDA)、桌上型计算机等,本申请实施例对电子设备的具体类型不作任何限制。
以下首先介绍本申请实施例涉及的电子设备。请参阅图1,图1示出了电子设备100的一种结构示意图。
如图1所示,电子设备100可以包括处理器110,外部存储器接口120,内部存储器121,通用串行总线(universal serial bus,USB)接口130,充电管理模块140,电源管理模块141,电池142,天线1,天线2,移动通信模块150,无线通信模块160,音频模块170,扬声器170A,受话器170B,麦克风170C,耳机接口170D,传感器模块180,按键190,马达191,指示器192,摄像头193,显示屏194,以及用户标识模块(subscriber identification module,SIM)卡接口195等。其中,传感器模块180可以包括压力传感器180A,陀螺仪传感器180B,气压传感器180C,磁传感器180D,加速度传感器180E,距离传感器180F,接近光传感器180G,指纹传感器180H,温度传感器180J,触摸传感器180K,环境光传感器180L,骨传导传感器180M等。
可以理解的是,本申请实施例示意的结构并不构成对电子设备100的具体限定。在本申请另一些实施例中,电子设备100可以包括比图示更多或更少的部件,或者组合某些部件,或者拆分某些部件,或者不同的部件布置。图示的部件可以以硬件,软件或软件和硬件的组合实现。
处理器110可以包括一个或多个处理单元,例如:处理器110可以包括应用处理器(application processor,AP),调制解调处理器,图形处理器(graphics processingunit,GPU),图像信号处理器(image signal processor,ISP),控制器,视频编解码器,数字信号处理器(digital signal processor,DSP),基带处理器,和/或神经网络处理器(neural-network processing unit,NPU)等。其中,不同的处理单元可以是独立的器件,也可以集成在一个或多个处理器中。
控制器可以根据指令操作码和时序信号,产生操作控制信号,完成取指令和执行指令的控制。
处理器110中还可以设置存储器,用于存储指令和数据。在一些实施例中,处理器110中的存储器为高速缓冲存储器。该存储器可以保存处理器110刚用过或循环使用的指令或数据。如果处理器110需要再次使用该指令或数据,可从所述存储器中直接调用。避免了重复存取,减少了处理器110的等待时间,因而提高了系统的效率。
在一些实施例中,处理器110可以包括一个或多个接口。接口可以包括集成电路(inter-integrated circuit,I2C)接口,集成电路内置音频(inter-integrated circuitsound,I2S)接口,脉冲编码调制(pulse code modulation,PCM)接口,通用异步收发传输器(universal asynchronous receiver/transmitter,UART)接口,移动产业处理器接口(mobile industry processor interface,MIPI),通用输入输出(general-purposeinput/output,GPIO)接口,用户标识模块(subscriber identity module,SIM)接口,和/或通用串行总线(universal serial bus,USB)接口等。
I2C接口是一种双向同步串行总线,包括一根串行数据线(serial data line,SDA)和一根串行时钟线(derail clock line,SCL)。在一些实施例中,处理器110可以包含多组I2C总线。处理器110可以通过不同的I2C总线接口分别耦合触摸传感器180K,充电器,闪光灯,摄像头193等。例如:处理器110可以通过I2C接口耦合触摸传感器180K,使处理器110与触摸传感器180K通过I2C总线接口通信,实现电子设备100的触摸功能。
I2S接口可以用于音频通信。在一些实施例中,处理器110可以包含多组I2S总线。处理器110可以通过I2S总线与音频模块170耦合,实现处理器110与音频模块170之间的通信。在一些实施例中,音频模块170可以通过I2S接口向无线通信模块160传递音频信号,实现通过蓝牙耳机接听电话的功能。
PCM接口也可以用于音频通信,将模拟信号抽样,量化和编码。在一些实施例中,音频模块170与无线通信模块160可以通过PCM总线接口耦合。在一些实施例中,音频模块170也可以通过PCM接口向无线通信模块160传递音频信号,实现通过蓝牙耳机接听电话的功能。所述I2S接口和所述PCM接口都可以用于音频通信。
UART接口是一种通用串行数据总线,用于异步通信。该总线可以为双向通信总线。它将要传输的数据在串行通信与并行通信之间转换。在一些实施例中,UART接口通常被用于连接处理器110与无线通信模块160。例如:处理器110通过UART接口与无线通信模块160中的蓝牙模块通信,实现蓝牙功能。在一些实施例中,音频模块170可以通过UART接口向无线通信模块160传递音频信号,实现通过蓝牙耳机播放音乐的功能。
MIPI接口可以被用于连接处理器110与显示屏194,摄像头193等外围器件。MIPI接口包括摄像头串行接口(camera serial interface,CSI),显示屏串行接口(displayserial interface,DSI)等。在一些实施例中,处理器110和摄像头193通过CSI接口通信,实现电子设备100的拍摄功能。处理器110和显示屏194通过DSI接口通信,实现电子设备100的显示功能。
GPIO接口可以通过软件配置。GPIO接口可以被配置为控制信号,也可被配置为数据信号。在一些实施例中,GPIO接口可以用于连接处理器110与摄像头193,显示屏194,无线通信模块160,音频模块170,传感器模块180等。GPIO接口还可以被配置为I2C接口,I2S接口,UART接口,MIPI接口等。
USB接口130是符合USB标准规范的接口,具体可以是Mini USB接口,Micro USB接口,USB Type C接口等。USB接口130可以用于连接充电器为电子设备100充电,也可以用于电子设备100与外围设备之间传输数据。也可以用于连接耳机,通过耳机播放音频。该接口还可以用于连接其他电子设备,例如AR设备等。
可以理解的是,本申请实施例示意的各模块间的接口连接关系,只是示意性说明,并不构成对电子设备100的结构限定。在本申请另一些实施例中,电子设备100也可以采用上述实施例中不同的接口连接方式,或多种接口连接方式的组合。
充电管理模块140用于从充电器接收充电输入。其中,充电器可以是无线充电器,也可以是有线充电器。在一些有线充电的实施例中,充电管理模块140可以通过USB接口130接收有线充电器的充电输入。在一些无线充电的实施例中,充电管理模块140可以通过电子设备100的无线充电线圈接收无线充电输入。充电管理模块140为电池142充电的同时,还可以通过电源管理模块141为电子设备供电。
电源管理模块141用于连接电池142,充电管理模块140与处理器110。电源管理模块141接收电池142和/或充电管理模块140的输入,为处理器110,内部存储器121,显示屏194,摄像头193,和无线通信模块160等供电。电源管理模块141还可以用于监测电池容量,电池循环次数,电池健康状态(漏电,阻抗)等参数。在其他一些实施例中,电源管理模块141也可以设置于处理器110中。在另一些实施例中,电源管理模块141和充电管理模块140也可以设置于同一个器件中。
电子设备100的无线通信功能可以通过天线1,天线2,移动通信模块150,无线通信模块160,调制解调处理器以及基带处理器等实现。
天线1和天线2用于发射和接收电磁波信号。电子设备100中的每个天线可用于覆盖单个或多个通信频带。不同的天线还可以复用,以提高天线的利用率。例如:可以将天线1复用为无线局域网的分集天线。在另外一些实施例中,天线可以和调谐开关结合使用。
移动通信模块150可以提供应用在电子设备100上的包括2G/3G/4G/5G等无线通信的解决方案。移动通信模块150可以包括至少一个滤波器,开关,功率放大器,低噪声放大器(low noise amplifier,LNA)等。移动通信模块150可以由天线1接收电磁波,并对接收的电磁波进行滤波,放大等处理,传送至调制解调处理器进行解调。移动通信模块150还可以对经调制解调处理器调制后的信号放大,经天线1转为电磁波辐射出去。在一些实施例中,移动通信模块150的至少部分功能模块可以被设置于处理器110中。在一些实施例中,移动通信模块150的至少部分功能模块可以与处理器110的至少部分模块被设置在同一个器件中。
调制解调处理器可以包括调制器和解调器。其中,调制器用于将待发送的低频基带信号调制成中高频信号。解调器用于将接收的电磁波信号解调为低频基带信号。随后解调器将解调得到的低频基带信号传送至基带处理器处理。低频基带信号经基带处理器处理后,被传递给应用处理器。应用处理器通过音频设备(不限于扬声器170A,受话器170B等)输出声音信号,或通过显示屏194显示图像或视频。在一些实施例中,调制解调处理器可以是独立的器件。在另一些实施例中,调制解调处理器可以独立于处理器110,与移动通信模块150或其他功能模块设置在同一个器件中。
无线通信模块160可以提供应用在电子设备100上的包括无线局域网(wirelesslocal area networks,WLAN)(如无线保真(wireless fidelity,Wi-Fi)网络),蓝牙(bluetooth,BT),全球导航卫星系统(global navigation satellite system,GNSS),调频(frequency modulation,FM),近距离无线通信技术(near field communication,NFC),红外技术(infrared,IR)等无线通信的解决方案。无线通信模块160可以是集成至少一个通信处理模块的一个或多个器件。无线通信模块160经由天线2接收电磁波,将电磁波信号调频以及滤波处理,将处理后的信号发送到处理器110。无线通信模块160还可以从处理器110接收待发送的信号,对其进行调频,放大,经天线2转为电磁波辐射出去。
在一些实施例中,电子设备100的天线1和移动通信模块150耦合,天线2和无线通信模块160耦合,使得电子设备100可以通过无线通信技术与网络以及其他设备通信。所述无线通信技术可以包括全球移动通讯系统(global system for mobile communications,GSM),通用分组无线服务(general packet radio service,GPRS),码分多址接入(codedivision multiple access,CDMA),宽带码分多址(wideband code division multipleaccess,WCDMA),时分码分多址(time-division code division multiple access,TD-SCDMA),长期演进(long term evolution,LTE),BT,GNSS,WLAN,NFC,FM,和/或IR技术等。所述GNSS可以包括全球卫星定位系统(global positioning system,GPS),全球导航卫星系统(global navigation satellite system,GLONASS),北斗卫星导航系统(beidounavigation satellite system,BDS),准天顶卫星系统(quasi-zenith satellitesystem,QZSS)和/或星基增强系统(satellite based augmentation systems,SBAS)。
电子设备100通过GPU,显示屏194,以及应用处理器等实现显示功能。GPU为图像处理的微处理器,连接显示屏194和应用处理器。GPU用于执行数学和几何计算,用于图形渲染。处理器110可包括一个或多个GPU,其执行程序指令以生成或改变显示信息。
显示屏194用于显示图像,视频等。显示屏194包括显示面板。显示面板可以采用液晶显示屏(liquid crystal display,LCD),有机发光二极管(organic light-emittingdiode,OLED),有源矩阵有机发光二极体或主动矩阵有机发光二极体(active-matrixorganic light emitting diode,AMOLED),柔性发光二极管(flex light-emittingdiode,FLED),Miniled,MicroLed,Micro-oLed,量子点发光二极管(quantum dot lightemitting diodes,QLED)等。在一些实施例中,电子设备100可以包括1个或N个显示屏194,N为大于1的正整数。
电子设备100可以通过ISP,摄像头193,视频编解码器,GPU,显示屏194以及应用处理器等实现拍摄功能。
ISP用于处理摄像头193反馈的数据。例如,拍照时,打开快门,光线通过镜头被传递到摄像头感光元件上,光信号转换为电信号,摄像头感光元件将所述电信号传递给ISP处理,转化为肉眼可见的图像。ISP还可以对图像的噪点,亮度,肤色进行算法优化。ISP还可以对拍摄场景的曝光,色温等参数优化。在一些实施例中,ISP可以设置在摄像头193中。
摄像头193用于捕获静态图像或视频。物体通过镜头生成光学图像投射到感光元件。感光元件可以是电荷耦合器件(charge coupled device,CCD)或互补金属氧化物半导体(complementary metal-oxide-semiconductor,CMOS)光电晶体管。感光元件把光信号转换成电信号,之后将电信号传递给ISP转换成数字图像信号。ISP将数字图像信号输出到DSP加工处理。DSP将数字图像信号转换成标准的RGB,YUV等格式的图像信号。在一些实施例中,电子设备100可以包括1个或N个摄像头193,N为大于1的正整数。
数字信号处理器用于处理数字信号,除了可以处理数字图像信号,还可以处理其他数字信号。例如,当电子设备100在频点选择时,数字信号处理器用于对频点能量进行傅里叶变换等。
视频编解码器用于对数字视频压缩或解压缩。电子设备100可以支持一种或多种视频编解码器。这样,电子设备100可以播放或录制多种编码格式的视频,例如:动态图像专家组(moving picture experts group,MPEG)1,MPEG2,MPEG3,MPEG4等。
NPU为神经网络(neural-network,NN)计算处理器,通过借鉴生物神经网络结构,例如借鉴人脑神经元之间传递模式,对输入信息快速处理,还可以不断的自学习。通过NPU可以实现电子设备100的智能认知等应用,例如:图像识别,人脸识别,语音识别,文本理解等。
外部存储器接口120可以用于连接外部存储卡,例如Micro SD卡,实现扩展电子设备100的存储能力。外部存储卡通过外部存储器接口120与处理器110通信,实现数据存储功能。例如将音乐,视频等文件保存在外部存储卡中。
内部存储器121可以用于存储计算机可执行程序代码,所述可执行程序代码包括指令。内部存储器121可以包括存储程序区和存储数据区。其中,存储程序区可存储操作系统,至少一个功能所需的应用程序(比如声音播放功能,图像播放功能等)等。存储数据区可存储电子设备100使用过程中所创建的数据(比如音频数据,电话本等)等。此外,内部存储器121可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件,闪存器件,通用闪存存储器(universal flash storage,UFS)等。处理器110通过运行存储在内部存储器121的指令,和/或存储在设置于处理器中的存储器的指令,执行电子设备100的各种功能应用以及数据处理。
电子设备100可以通过音频模块170,扬声器170A,受话器170B,麦克风170C,耳机接口170D,以及应用处理器等实现音频功能。例如音乐播放,录音等。
音频模块170用于将数字音频信息转换成模拟音频信号输出,也用于将模拟音频输入转换为数字音频信号。音频模块170还可以用于对音频信号编码和解码。在一些实施例中,音频模块170可以设置于处理器110中,或将音频模块170的部分功能模块设置于处理器110中。
扬声器170A,也称“喇叭”,用于将音频电信号转换为声音信号。电子设备100可以通过扬声器170A收听音乐,或收听免提通话。
受话器170B,也称“听筒”,用于将音频电信号转换成声音信号。当电子设备100接听电话或语音信息时,可以通过将受话器170B靠近人耳接听语音。
麦克风170C,也称“话筒”,“传声器”,用于将声音信号转换为电信号。当拨打电话或发送语音信息时,用户可以通过人嘴靠近麦克风170C发声,将声音信号输入到麦克风170C。电子设备100可以设置至少一个麦克风170C。在另一些实施例中,电子设备100可以设置两个麦克风170C,除了采集声音信号,还可以实现降噪功能。在另一些实施例中,电子设备100还可以设置三个,四个或更多麦克风170C,实现采集声音信号,降噪,还可以识别声音来源,实现定向录音功能等。
耳机接口170D用于连接有线耳机。耳机接口170D可以是USB接口130,也可以是3.5mm的开放移动电子设备平台(open mobile terminal platform,OMTP)标准接口,美国蜂窝电信工业协会(cellular telecommunications industry association of the USA,CTIA)标准接口。
压力传感器180A用于感受压力信号,可以将压力信号转换成电信号。在一些实施例中,压力传感器180A可以设置于显示屏194。压力传感器180A的种类很多,如电阻式压力传感器,电感式压力传感器,电容式压力传感器等。电容式压力传感器可以是包括至少两个具有导电材料的平行板。当有力作用于压力传感器180A,电极之间的电容改变。电子设备100根据电容的变化确定压力的强度。当有触摸操作作用于显示屏194,电子设备100根据压力传感器180A检测所述触摸操作强度。电子设备100也可以根据压力传感器180A的检测信号计算触摸的位置。在一些实施例中,作用于相同触摸位置,但不同触摸操作强度的触摸操作,可以对应不同的操作指令。例如:当有触摸操作强度小于第一压力阈值的触摸操作作用于短消息应用图标时,执行查看短消息的指令。当有触摸操作强度大于或等于第一压力阈值的触摸操作作用于短消息应用图标时,执行新建短消息的指令。
陀螺仪传感器180B可以用于确定电子设备100的运动姿态。在一些实施例中,可以通过陀螺仪传感器180B确定电子设备100围绕三个轴(即,x,y和z轴)的角速度。陀螺仪传感器180B可以用于拍摄防抖。示例性的,当按下快门,陀螺仪传感器180B检测电子设备100抖动的角度,根据角度计算出镜头模组需要补偿的距离,让镜头通过反向运动抵消电子设备100的抖动,实现防抖。陀螺仪传感器180B还可以用于导航,体感游戏场景。
气压传感器180C用于测量气压。在一些实施例中,电子设备100通过气压传感器180C测得的气压值计算海拔高度,辅助定位和导航。
磁传感器180D包括霍尔传感器。电子设备100可以利用磁传感器180D检测翻盖皮套的开合。在一些实施例中,当电子设备100是翻盖机时,电子设备100可以根据磁传感器180D检测翻盖的开合。进而根据检测到的皮套的开合状态或翻盖的开合状态,设置翻盖自动解锁等特性。
加速度传感器180E可检测电子设备100在各个方向上(一般为三轴)加速度的大小。当电子设备100静止时可检测出重力的大小及方向。还可以用于识别电子设备姿态,应用于横竖屏切换,计步器等应用。
距离传感器180F,用于测量距离。电子设备100可以通过红外或激光测量距离。在一些实施例中,拍摄场景,电子设备100可以利用距离传感器180F测距以实现快速对焦。
接近光传感器180G可以包括例如发光二极管(LED)和光检测器,例如光电二极管。发光二极管可以是红外发光二极管。电子设备100通过发光二极管向外发射红外光。电子设备100使用光电二极管检测来自附近物体的红外反射光。当检测到充分的反射光时,可以确定电子设备100附近有物体。当检测到不充分的反射光时,电子设备100可以确定电子设备100附近没有物体。电子设备100可以利用接近光传感器180G检测用户手持电子设备100贴近耳朵通话,以便自动熄灭屏幕达到省电的目的。接近光传感器180G也可用于皮套模式,口袋模式自动解锁与锁屏。
环境光传感器180L用于感知环境光亮度。电子设备100可以根据感知的环境光亮度自适应调节显示屏194亮度。环境光传感器180L也可用于拍照时自动调节白平衡。环境光传感器180L还可以与接近光传感器180G配合,检测电子设备100是否在口袋里,以防误触。
指纹传感器180H用于采集指纹。电子设备100可以利用采集的指纹特性实现指纹解锁,访问应用锁,指纹拍照,指纹接听来电等。
温度传感器180J用于检测温度。在一些实施例中,电子设备100利用温度传感器180J检测的温度,执行温度处理策略。例如,当温度传感器180J上报的温度超过阈值,电子设备100执行降低位于温度传感器180J附近的处理器的性能,以便降低功耗实施热保护。在另一些实施例中,当温度低于另一阈值时,电子设备100对电池142加热,以避免低温导致电子设备100异常关机。在其他一些实施例中,当温度低于又一阈值时,电子设备100对电池142的输出电压执行升压,以避免低温导致的异常关机。
触摸传感器180K,也称“触控器件”。触摸传感器180K可以设置于显示屏194,由触摸传感器180K与显示屏194组成触摸屏,也称“触控屏”。触摸传感器180K用于检测作用于其上或附近的触摸操作。触摸传感器可以将检测到的触摸操作传递给应用处理器,以确定触摸事件类型。可以通过显示屏194提供与触摸操作相关的视觉输出。在另一些实施例中,触摸传感器180K也可以设置于电子设备100的表面,与显示屏194所处的位置不同。
骨传导传感器180M可以获取振动信号。在一些实施例中,骨传导传感器180M可以获取人体声部振动骨块的振动信号。骨传导传感器180M也可以接触人体脉搏,接收血压跳动信号。在一些实施例中,骨传导传感器180M也可以设置于耳机中,结合成骨传导耳机。音频模块170可以基于所述骨传导传感器180M获取的声部振动骨块的振动信号,解析出语音信号,实现语音功能。应用处理器可以基于所述骨传导传感器180M获取的血压跳动信号解析心率信息,实现心率检测功能。
按键190包括开机键,音量键等。按键190可以是机械按键。也可以是触摸式按键。电子设备100可以接收按键输入,产生与电子设备100的用户设置以及功能控制有关的键信号输入。
马达191可以产生振动提示。马达191可以用于来电振动提示,也可以用于触摸振动反馈。例如,作用于不同应用(例如拍照,音频播放等)的触摸操作,可以对应不同的振动反馈效果。作用于显示屏194不同区域的触摸操作,马达191也可对应不同的振动反馈效果。不同的应用场景(例如:时间提醒,接收信息,闹钟,游戏等)也可以对应不同的振动反馈效果。触摸振动反馈效果还可以支持自定义。
指示器192可以是指示灯,可以用于指示充电状态,电量变化,也可以用于指示消息,未接来电,通知等。
SIM卡接口195用于连接SIM卡。SIM卡可以通过插入SIM卡接口195,或从SIM卡接口195拔出,实现和电子设备100的接触和分离。电子设备100可以支持1个或N个SIM卡接口,N为大于1的正整数。SIM卡接口195可以支持Nano SIM卡,Micro SIM卡,SIM卡等。同一个SIM卡接口195可以同时插入多张卡。所述多张卡的类型可以相同,也可以不同。SIM卡接口195也可以兼容不同类型的SIM卡。SIM卡接口195也可以兼容外部存储卡。电子设备100通过SIM卡和网络交互,实现通话以及数据通信等功能。在一些实施例中,电子设备100采用eSIM,即:嵌入式SIM卡。eSIM卡可以嵌在电子设备100中,不能和电子设备100分离。
电子设备100的软件系统可以采用分层架构,事件驱动架构,微核架构,微服务架构,或云架构。本申请实施例以分层架构的Android系统为例,示例性说明电子设备100的软件结构。
图2是本申请实施例的电子设备100的软件结构框图。
分层架构将软件分成若干个层,每一层都有清晰的角色和分工。层与层之间通过软件接口通信。在一些实施例中,将Android系统分为四层,从上至下分别为应用程序层,应用程序框架层,安卓运行时(Android runtime)和系统库,以及内核层。
应用程序层可以包括一系列应用程序包。
如图2所示,应用程序包可以包括相机,图库,日历,通话,地图,导航,WLAN,蓝牙,音乐,视频,智能健身等应用程序。
应用程序框架层为应用程序层的应用程序提供应用编程接口(applicationprogramming interface,API)和编程框架。应用程序框架层包括一些预先定义的函数。
如图2所示,应用程序框架层可以包括窗口管理器,内容提供器,视图系统,电话管理器,资源管理器,通知管理器等。
窗口管理器用于管理窗口程序。窗口管理器可以获取显示屏大小,判断是否有状态栏,锁定屏幕,截取屏幕等。
内容提供器用来存放和获取数据,并使这些数据可以被应用程序访问。所述数据可以包括视频,图像,音频,拨打和接听的电话,浏览历史和书签,电话簿等。
视图系统包括可视控件,例如显示文字的控件,显示图片的控件等。视图系统可用于构建应用程序。显示界面可以由一个或多个视图组成的。例如,包括短信通知图标的显示界面,可以包括显示文字的视图以及显示图片的视图。
电话管理器用于提供电子设备100的通信功能。例如通话状态的管理(包括接通,挂断等)。
资源管理器为应用程序提供各种资源,比如本地化字符串,图标,图片,布局文件,视频文件等等。
通知管理器使应用程序可以在状态栏中显示通知信息,可以用于传达告知类型的消息,可以短暂停留后自动消失,无需用户交互。比如通知管理器被用于告知下载完成,消息提醒等。通知管理器还可以是以图表或者滚动条文本形式出现在系统顶部状态栏的通知,例如后台运行的应用程序的通知,还可以是以对话窗口形式出现在屏幕上的通知。例如在状态栏提示文本信息,发出提示音,电子设备振动,指示灯闪烁等。
Android Runtime包括核心库和虚拟机。Android runtime负责安卓系统的调度和管理。
核心库包含两部分:一部分是java语言需要调用的功能函数,另一部分是安卓的核心库。
应用程序层和应用程序框架层运行在虚拟机中。虚拟机将应用程序层和应用程序框架层的java文件执行为二进制文件。虚拟机用于执行对象生命周期的管理,堆栈管理,线程管理,安全和异常的管理,以及垃圾回收等功能。
系统库可以包括多个功能模块。例如:表面管理器(surface manager),媒体库(Media Libraries),三维图形处理库(例如:OpenGL ES),2D图形引擎(例如:SGL)等。
表面管理器用于对显示子系统进行管理,并且为多个应用程序提供了2D和3D图层的融合。
媒体库支持多种常用的音频,视频格式回放和录制,以及静态图像文件等。媒体库可以支持多种音视频编码格式,例如:MPEG4,H.264,MP3,AAC,AMR,JPG,PNG等。
三维图形处理库用于实现三维图形绘图,图像渲染,合成,和图层处理等。
2D图形引擎是2D绘图的绘图引擎。
内核层是硬件和软件之间的层。内核层至少包含显示驱动,摄像头驱动,音频驱动,传感器驱动。
【实施例一】
以下将结合附图和具体应用场景对本申请实施例一提供的应用下载安装方法进行详细说明。
本申请实施例中,可以将应用的安装包拆分成多个子包。当某一电子设备需下载安装该应用时,该电子设备需要下载该应用的全部子包,以根据全部子包来安装得到该应用。而当该电子设备仅获取该应用的部分子包时,该电子设备将无法安装得到该应用,或者安装得到的应用会存在全部或者部分功能无法使用的问题。
本申请实施例中,开发人员可以分别对各个子包进行开发,从而可以提高应用开发的便利性。例如,在免安装的应用(即无需显式安装,由系统程序框架后台安装后即可使用的应用,如原子化服务、特性能力(feature ability,FA)中,开发人员可以按照功能将应用的安装包拆分成一个或者多个鸿蒙能力包(harmonyos ability package,hap),一个hap对应一个ability,ability是应用所具备能力的抽象,是应用的重要组成部分。每一个ability均可独立运行,可完成一个特定的功能,一个或者多个功能可完成一个特定的便捷服务。以下将以免安装的应用为例对本实施例提供的应用下载安装方法进行示例性说明。
对于每一个免安装的应用,由于该应用往往需要应用于不同类型的电子设备,因此,开发人员需要针对不同类型的电子设备来开发该应用的各个安装包。本实施例中,开发人员可以按照功能将该应用的每一个安装包划分成一个或多个子包,并分别对各子包进行开发,得到各个安装包对应的子包。然后,开发人员可以将各个安装包对应的子包发送给云端(也可以称为服务器)。云端接收到各个安装包对应的子包后,可以将安装包至少划分为第一部分和第二部分,第一部分可以包括第一子包,第二部分可以包括第二子包。其中,第一子包和第二子包均可以包括一个或者多个。第一子包可以为应用的基础部分,即可以为该应用的各个安装包中均具有的子包,也就是说,第一子包为可以在不同类型的电子设备中共用的数据包。第二子包可以为特性部分,即第二子包可以为某一安装包所特有的子包,也就是说,第二子包为与某一类型的电子设备的特性(或属性)所对应的数据包。或者,开发人员开发得到各个安装包对应的子包后,可以先自行将子包划分为第一部分和第二部分,然后可以将第一部分和第二部分发送给云端。因此,对于任一应用,云端可以存储该应用的第一子包以及分别与各类型的电子设备对应的各第二子包,以减少云端针对各应用所存储的数据包的数量,减少云端的存储负担。
可以理解的是,上述描述的第一部分为基础部分,第二部分为特性部分,仅作示意性解释,不应理解为对本申请实施例的限制,本申请实施例中,也可以是第一部分为特性部分,第二部分为共有部分。以下将以第一部分为基础部分,第二部分为特性部分为例进行示例性说明。
请参阅图3,图3示出了本实施例提供的应用下载安装方法所应用的系统结构图。如图3所示,该系统可以包括云端300、第一电子设备110和至少一个第二电子设备120。其中,第一电子设备110为需进行应用下载的电子设备,第二电子设备120为通过通信网络与第一电子设备110通信连接的电子设备。第一电子设备110还可以通过通信网络与云端300通信连接,云端300存储有可以应用于第一电子设备110的各应用的第一子包和第二子包。如图3中的(a)所示,第一电子设备110与第二电子设备120(图3中的(a)中以一个为例进行示例性说明)可以为同类型的电子设备,例如均可以为手机,此时云端300可以存储有可以应用于手机的各应用的第一子包和各第二子包。例如,在通话应用和音乐应用可以应用于手机时,云端300可以存储有该通话应用的第一子包R和第二子包A,以及存储有该音乐应用的第一子包S和第二子包B。
应理解,当第一电子设备110与第二电子设备120为同类型的电子设备,但具有不同的特性时,也就是说,当第一电子设备110和第二电子设备120为同类型的电子设备,但具有不同的第二子包时,可以将第一电子设备110作为与第二电子设备120不同类型的电子设备来进行应用的下载安装。
其中,第一电子设备110可以根据是否检测到下载第一应用的触发事件,来确定是否需进行第一应用的下载。应理解,第一应用可以为任一应用。示例性的,第一应用可以为FA,触发事件可以为对未安装的FA的点击或者触摸操作等。或者,第一应用可以为应用市场中某一个未安装的应用,触发事件可以为对该应用对应的安装或下载按钮的点击或者触摸操作等。
或者,如图3中的(b)所示,第一电子设备110与第二电子设备120(图3中的(b)中以四个为例进行示例性说明)也可以为不同类型的电子设备,例如第一电子设备110可以为手机,第二电子设备120可以分别为智能手表、电脑、平板电脑和智慧大屏,此时云端300可以存储有可以应用于第一电子设备110的各应用的第一子包和第二子包。其中,可以应用于第一电子设备110的各应用也可以应用于至少一种类型的第二电子设备120,因此,各应用的第二子包至少可以包括与第一电子设备110对应的第二子包以及与至少一种类型的第二电子设备120对应的第二子包。例如,在通话应用可以应用于手机、智能手表、电脑、平板电脑和智慧大屏时,云端300可以存储有该通话应用的第一子包R,以及与手机对应的第二子包A、与智能手表对应的第二子包B、与电脑对应的第二子包C、与平板电脑对应的第二子包D、与智慧大屏对应的第二子包E;例如,在音乐应用可以应用于手机、电脑、平板电脑和智慧大屏时,云端300还可以存储有该音乐应用的第一子包S,以及与手机对应的第二子包F、与电脑对应的第二子包G、与平板电脑对应的第二子包H、与智慧大屏对应的第二子包I;例如,在智能健身应用可以应用于手机、智能手表和智慧大屏时,云端300还可以存储有该智能健身应用的第一子包T,以及与手机对应的第二子包J、与智能手表对应的第二子包K、与智慧大屏对应的第二子包L,等等。
在此,通信网络可以是蓝牙、WiFi、紫蜂(ZigBee)或者NFC等局域网,也可以是2G、3G、4G、5G、未来演进的公共陆地移动网络(public land mobile network,PLMN)或者因特网等广域网。
下面以应用的第一子包以及与各类型的电子设备对应的第二子包分别包括多个为例,对第一电子设备110下载应用的过程进行详细说明。
可以理解的是,在第一电子设备110需要下载某一应用时,各第二电子设备120是否已下载该应用会使得第一电子设备110下载该应用的过程有所不同。下面从各第二电子设备120均未下载该应用和存在第二电子设备120已下载该应用两个方面来对第一电子设备110下载该应用的过程进行详细说明。
一、各第二电子设备120均未下载该应用
本实施例中,在第一电子设备110需要下载某一个应用时,第一电子设备110可以先确定各第二电子设备120是否已下载该应用。当各第二电子设备120均未下载该应用时,表明只有云端300存储有该应用的第一子包和各第二子包,此时,第一电子设备110可以从云端300下载该应用的第一子包以及与第一电子设备110对应的第二子包。例如,在图3中的(b)所示的应用场景中,在手机需要下载通话应用时,若智能手表、电脑、平板电脑和智慧大屏均未下载该通话应用,表明只有云端300存储有该通话应用的第一子包R和各第二子包(即A、B、C、D、E),此时手机可以从云端300下载该通话应用的第一子包R以及与手机对应的第二子包A。
示例性的,第一电子设备110可以根据各第二电子设备120中该应用的子包信息来确定各第二电子设备120是否已下载该应用。具体地,在需要下载该应用时,第一电子设备110可以向云端300发送第一查询请求,以请求查询该应用的子包信息,例如第一电子设备110可以调用pagequery接口,向云端300发送第一查询请求。云端300接收到第一查询请求之后,可以查询该应用的子包信息,并可以将所查询到的子包信息以数组形式(例如{子包1、子包2、……、子包n})返回给第一电子设备110。随后,第一电子设备110可以分别向各第二电子设备120发送第二查询请求,以请求查询各第二电子设备120中该应用的子包信息,例如第一电子设备110可以调用queryDevicesFa接口,分别向各第二电子设备120发送第二查询请求。各第二电子设备120接收到第二查询请求之后,可以查询各第二电子设备120中该应用的相关信息,并可以将查询结果发送给第一电子设备110。然后,第一电子设备110可以根据各第二电子设备120返回的查询结果和云端300返回的子包信息确定各第二电子设备120是否已下载该应用。
需要说明的是,一般只有该应用可以应用的电子设备才会下载该应用,因此在第一电子设备110需要下载该应用时,第一电子设备110可以先确定该应用可以应用的电子设备的类型。然后,第一电子设备110可以确定这些类型的第二电子设备120是否已下载该应用。即第一电子设备110只需要向这些类型的第二电子设备120发送第二查询请求来查询该应用的相关信息,而不需要向每一个第二电子设备120发送第二查询请求,减少查询数量,提高查询效率,提高第一电子设备110的应用下载速度。
例如,在图3中的(b)所示的应用场景中,在手机需要下载智能健身应用时,手机可以先确定该智能健身应用可以应用的电子设备的类型,假定该智能健身应用可以应用的电子设备的类型为手机、智能手表和智慧大屏,此时,手机可以仅分别向智能手表和智慧大屏发送第二查询请求,以请求查询智能手表和智慧大屏中是否具有该智能健身应用的相关信息。当确定智能手表中具有该智能健身应用的相关信息,而智慧大屏中不具有该智能健身应用的相关信息时,手机可以确定智能手表已下载该智能健身应用,智慧大屏并未下载该智能健身应用。
可以理解的是,开发人员在将某一应用的安装包上传至云端300时,可以同时上传该应用可以应用的电子设备的类型;或者云端300获取某一应用的安装包后,可以根据该应用的安装包(例如该安装包中的各第二子包)来确定该应用可以应用的电子设备的类型。即云端300可以存储有各应用可以应用的电子设备的类型。因此,第一电子设备110可以直接向云端300发送类型查询请求,来查询该应用可以应用的电子设备的类型。
请参阅图4和图5,图4和图5示出了本实施例提供的应用场景示意图一。如图4和图5所示,在该应用场景中,当各第二电子设备120均未下载该应用时,第一电子设备110可以向至少一个第二电子设备120发送下载指令,该下载指令用于指示该至少一个第二电子设备120从云端300下载该应用的第一子包和/或下载与第一电子设备110对应的第二子包,并将所下载的第一子包和/或第二子包发送给第一电子设备110。
在一个示例中,第一电子设备110可以指示某一第二电子设备120从云端300下载与第一电子设备110对应的完整安装包(即该应用的第一子包以及与第一电子设备110对应的第二子包)。具体地,第一电子设备110可以先确定各第二电子设备120从云端300下载该完整安装包的第一时间以及各第二电子设备120将该完整安装包发送给第一电子设备110的第二时间。然后,第一电子设备110可以将第一时间和第二时间之和最短的第二电子设备120确定为最终从云端300下载该完整安装包的第二电子设备120,并向所确定的第二电子设备120发送下载指令,以指示其从云端300下载该应用的第一子包以及与第一电子设备110对应的第二子包,并将所下载的第一子包和第二子包发送给第一电子设备110,即通过性能较好的第二电子设备来进行应用的下载,可以减少第一电子设备110下载应用的时间,提高第一电子设备110的下载速度,提升用户体验。
例如,在图3中的(b)所示的应用场景中,在手机需要下载音乐应用,且智能手表、电脑、平板电脑以及智慧大屏均未下载该音乐应用时,手机可以先确定智能手表从云端300下载该音乐应用的第一子包S以及与手机对应的第二子包F的第一时间TW1以及将第一子包S和第二子包F发送给手机的第二时间TW2,电脑从云端300下载第一子包S和第二子包F的第一时间TC1以及将第一子包S和第二子包F发送给手机的第二时间TC2,平板电脑从云端300下载第一子包S和第二子包F的第一时间TP1以及将第一子包S和第二子包F发送给手机的第二时间TP2,智慧大屏从云端300下载第一子包S和第二子包F的第一时间TS1以及将第一子包S和第二子包F发送给手机的第二时间TS2。假设手机确定(TP1+TP2)<(TW1+TW2)<(TC1+TC2)<(TS1+TS2),手机可以将平板电脑确定为从云端300下载第一子包S和第二子包F的第二电子设备,此时,如图4中的(a)所示,手机可以向平板电脑发送下载指令,以指示平板电脑从云端300下载该音乐应用的第一子包S和第二子包F,并将所下载的第一子包S和第二子包F发送给手机。平板电脑接收到下载指令时,可以向云端300发送下载请求,以请求下载第一子包S和第二子包F。
本实施例中,任一第二电子设备120从云端300下载该完整安装包的第一时间可以根据第二电子设备120与云端300之间的网络传输速度和该完整安装包的大小volumeall确定。假设第j个第二电子设备120从云端300下载该完整安装包时,需经过时间tj,delay1达到稳定速度vj,max1,那么第j个第二电子设备120从云端300下载该完整安装包的第一时间Tj1=tj,delay1+max(volumeall–volume1,0)/vj,max1,volume1为在时间tj,delay1内,第二电子设备120从云端300下载的安装包的大小。
类似的,第二电子设备120将该完整安装包发送给第一电子设备110的第二时间可以根据第二电子设备120与第一电子设备110之间的网络传输速度和该完整安装包的大小volumeall确定。假设第j个第二电子设备120将该完整安装包传输给第一电子设备110时,需经过时间tj,delay2达到稳定速度vj,max2,那么第j个第二电子设备120将该完整安装包发送给第一电子设备110的第二时间Tj2=tj,delay2+max(volumeall-volume2,0)/vj,max2,volume2为在时间tj,delay2内,第二电子设备120传输给第一电子设备110的安装包的大小。
其中,第二电子设备120与云端300之间的网络传输速度是指第一电子设备110请求下载该应用时,第二电子设备120与云端300之间所连接网络的传输速度。同样的,第二电子设备120与第一电子设备110之间的网络传输速度是指第一电子设备110请求下载该应用时,第二电子设备120与第一电子设备110之间所连接网络的传输速度。可以理解的是,第二电子设备120与云端300之间的网络传输速度,以及第二电子设备120与第一电子设备110之间的网络传输速度可以根据实际情况确定。
需要说明的是,上述将第一时间和第二时间之和最短的第二电子设备确定为最终从云端300下载该完整安装包的第二电子设备120仅作示意性解释,不应理解为对本申请实施例的限制。本申请实施例中,第一电子设备110也可以获取第一时间和第二时间之和小于或等于预设时间阈值的第二电子设备,并从这些第二电子设备中确定最终从云端300下载该完整安装包的电子设备。
示例性的,第一电子设备110可以根据这些第二电子设备当前的使用情况和/或设备性能来确定最终从云端300下载该完整安装包的电子设备,例如可以将当前处于空闲状态的第二电子设备确定为最终云端300下载该完整安装包的电子设备。
示例性的,第一电子设备110可以根据用户的选择操作来确定最终从云端300下载该完整安装包的电子设备,即用户可以自行从这些第二电子设备中选择最终从云端300下载该完整安装包的电子设备。
其中,预设时间阈值可以由第一电子设备110默认设置,也可以由用户自定义设置,例如用户可以根据自身所能接受的最大下载时间来设置预设时间阈值,如将预设时间阈值自定义设置为40秒、60秒或80秒,等等。
类似的,后续将第三时间和第四时间(或第五时间和第六时间)之和最短的第二电子设备确定为最终从云端300下载第一子包或第二子包的第二电子设备120也仅作示意性解释,不应理解为对本申请实施例的限制。
在另一个示例中,第一电子设备110可以指示某一第二电子设备120从云端300下载该应用的全部第一子包,同时第一电子设备110可以从云端300下载与第一电子设备110对应的全部第二子包;或者,第一电子设备110可以指示某一第二电子设备120从云端300下载与第一电子设备110对应的全部第二子包,同时第一电子设备110可以从云端300下载该应用的全部第一子包;或者,第一电子设备110可以指示某一第二电子设备120从云端300下载该应用的全部第一子包,同时指示另一第二电子设备120从云端300下载与第一电子设备110对应的全部第二子包,以通过第一电子设备110和第二电子设备120,或者多个第二电子设备120分布式下载该应用的安装包,减少第一电子设备110下载应用的时间,提高第一电子设备110的下载速度。
在一种可能的实现方式中,第一电子设备110可以确定各第二电子设备120从云端300下载全部第一子包的第三时间以及将所下载的第一子包发送给第一电子设备110的第四时间。然后,第一电子设备110可以将第三时间和第四时间之和最短的第二电子设备120确定为最终从云端300下载全部第一子包的第二电子设备120,并向所确定的第二电子设备120发送下载指令,以指示其从云端300下载该应用的全部第一子包,并可以将所下载的第一子包发送给第一电子设备110,同时第一电子设备110可以从云端300下载与第一电子设备110对应的全部第二子包。
例如,在图3中的(b)所示的应用场景中,当手机需要下载通话应用,且智能手表、电脑、平板电脑以及智慧大屏均未下载该通话应用时,手机可以先确定智能手表从云端300下载该通话应用的第一子包R的第三时间TW13以及将第一子包R发送给手机的第四时间TW14,电脑从云端300下载第一子包R的第三时间TC13以及将第一子包R发送给手机的第四时间TC14,平板电脑从云端300下载第一子包R的第三时间TP13以及将第一子包R发送给手机的第四时间TP13,智慧大屏从云端300下载第一子包R的第三时间TS13以及将第一子包R发送给手机的第四时间TS14。假设手机确定(TC13+TC14)<(TP13+TP14)<(TS13+TS14)<(TW13+TW14),手机可以将电脑确定为从云端300下载第一子包R的第二电子设备,此时,如图4中的(b)所示,手机可以向电脑发送下载指令,以指示电脑从云端300下载该通话应用的第一子包R,并将所下载的第一子包R发送给手机。电脑接收到下载指令时,可以向云端300发送第一下载请求,以请求下载第一子包R。同时,手机可以向云端300发送第二下载请求,以请求下载与手机对应的第二子包A。
在另一种可能的实现方式中,第一电子设备110可以确定各第二电子设备120从云端300下载与第一电子设备110对应的全部第二子包的第三时间以及将所下载的第二子包发送给第一电子设备110的第四时间。然后,第一电子设备110可以将第三时间和第四时间之和最短的第二电子设备120确定为最终从云端300下载第二子包的第二电子设备120,并向所确定的第二电子设备120发送下载指令,以指示其从云端300下载与第一电子设备110对应的全部第二子包,并将所下载的第二子包发送给第一电子设备110,同时第一电子设备110可以从云端300下载该应用的第一子包。
例如,在图3中的(b)所示的应用场景中,当手机需要下载通话应用,且智能手表、电脑、平板电脑以及智慧大屏均未下载该通话应用时,手机可以先确定智能手表从云端300下载与第一电子设备110对应的第二子包A的第三时间TW23以及将第二子包A发送给手机的第四时间TW24,电脑从云端300下载第二子包A的第三时间TC23以及将第二子包A发送给手机的第四时间TC24,平板电脑从云端300下载第二子包A的第三时间TP23以及将第二子包A发送给手机的第四时间TP24,智慧大屏从云端300下载第二子包A的第三时间TS23以及将第二子包A发送给手机的第四时间TS24。假设,手机确定(TS23+TS24)<(TC23+TC24)<(TP23+TP24)<(TW23+TW24),手机可以将智慧大屏确定为从云端300下载第二子包A的第二电子设备,此时,如图5中的(a)所示,手机可以向智慧大屏发送下载指令,以指示智慧大屏从云端300下载该通话应用的第二子包A,并将所下载的第二子包A发送给手机。智慧大屏接收到下载指令时,可以向云端300发送第一下载请求,以请求下载第二子包A。同时,手机可以向云端300发送第二下载请求,以请求下载该通话应用的第一子包R。
在另一种可能的实现方式中,第一电子设备120可以确定各第二电子设备120从云端300下载该应用的全部第一子包的第三时间以及将所下载的第一子包发送给第一电子设备110的第四时间,并确定各第二电子设备120从云端300下载与第一电子设备110对应的全部第二子包的第五时间以及将所下载的第二子包发送给第一电子设备110的第六时间。然后,第一电子设备110可以将第三时间与第四时间之和最短的第二电子设备a确定为从云端300下载该应用的全部第一子包的电子设备,并可以将第五时间与第六时间之和最短的第二电子设备b确定为从云端300下载与第一电子设备110对应的第二子包的电子设备。此时,第一电子设备110可以向第二电子设备a发送第一下载指令,并同时向第二电子设备b发送第二下载指令,第一下载指令用于指示下载该应用的全部第一子包,并将所下载的第一子包发送给第一电子设备110,第二下载指令用于指示下载与第一电子设备110对应的全部第二子包,并将所下载的第二子包发送给第一电子设备110。
例如,在图3中的(b)所示的应用场景中,当手机需要下载通话应用,且智能手表、电脑、平板电脑以及智慧大屏均未下载该通话应用时,手机可以先确定智能手表从云端300下载该通话应用的全部第一子包R的第三时间TW13以及将第一子包R发送给手机的第四时间TW14,电脑从云端300下载第一子包R的第三时间TC13以及将第一子包R发送给手机的第四时间TC14,平板电脑从云端300下载第一子包R的第三时间TP13以及将第一子包R发送给手机的第四时间TP14,智慧大屏从云端300下载第一子包R的第三时间TS13以及将第一子包R发送给手机的第四时间TS14。同时,第一电子设备110还可以确定智能手表从云端300下载与第一电子设备110对应的第二子包A的第五时间TW25以及将第二子包A发送给手机的第六时间TW26,电脑从云端300下载第二子包A的第五时间TC25以及将第二子包A发送给手机的第六时间TC26,平板电脑从云端300下载第二子包A的第五时间TP25以及将第二子包A发送给手机的第六时间TP26,智慧大屏从云端300下载第二子包A的第五时间TS25以及将第二子包A发送给手机的第六时间TS26。假设手机确定(TC13+TC14)<(TS13+TS14)<(TP13+TP14)<(TW13+TW14),且(TS25+TS26)<(TC25+TC26)<(TP25+TP26)<(TW25+TW26),手机可以将电脑确定为从云端300下载第一子包R的第二电子设备,并将智慧大屏确定为从云端300下载第二子包A的第二电子设备,如图5中的(b)所示,手机可以向电脑发送第一下载指令,以指示电脑从云端300下载第一子包R,并将所下载的第一子包R发送给手机,同时,手机可以向智慧大屏发送第二下载指令,以指示智慧大屏从云端300下载第二子包A,并将所下载的第二子包A发送给手机。电脑接收到第一下载指令时,可以向云端300发送第一下载请求,以请求下载第一子包R。智慧大屏接收到第二下载指令时,可以向云端300发送第二下载请求,以请求下载第二子包A。
其中,上述的第三时间、第四时间、第五时间以及第六时间的确定方式与前述的第一时间或第二时间的确定方式相类似,原理基本相同,具体内容可以参照前述描述,在此不再赘述。
需要说明的是,当第二电子设备a与第二电子设备b为同一电子设备时,第一电子设备110可以获取第三时间与第四时间之和仅大于Ta的第二电子设备c,并获取第五时间与第六时间之和仅大于Tb的第二电子设备d。其中,Ta为第二电子设备a对应的第三时间与第四时间之和,Tb为第二电子设备b对应的第五时间和第六时间之和。以下将第二电子设备c对应的第三时间与第四时间之和表示为Tc,将第二电子设备d对应的第五时间与第六时间之和表示为Td。同时,第一电子设备110可以确定第二电子设备a下载全部第一子包以及与第一电子设备110对应的全部第二子包的时间Ta’。随后,第一电子设备110确定Tc与Td中的较小值,并根据该较小值、Ta、Tb以及Ta’来进行该应用的下载。
例如,当Tc<Td,且(Tb+Tc)<Ta’时,第一电子设备110可以确定由第二电子设备c下载该应用的全部第一子包,同时由第二电子设备b下载与第一电子设备110对应的全部第二子包。当Tc>Td,且(Ta+Td)<Ta’时,第一电子设备110可以确定由第二电子设备a下载该应用的全部第一子包,同时由第二电子设备d下载与第一电子设备110对应的全部第二子包。当Tc<Td,且(Tb+Tc)>Ta’时,或者当Tc>Td,且(Ta+Td)>Ta’时,第一电子设备110可以确定由第二电子设备a下载该应用的全部第一子包以及与第一电子设备110对应的全部第二子包。
在另一个示例中,第一电子设备110可以指示第一电子设备110与第二电子设备120中的至少两个电子设备分布式下载该应用的第一子包。或者,第一电子设备110可以指示第一电子设备110与第二电子设备120中的至少两个电子设备分布式下载与第一电子设备110对应的第二子包。或者,第一电子设备110可以指示第一电子设备110与第二电子设备120中的至少两个电子设备分布式下载该应用的安装包(即第一子包以及与第一电子设备110对应的第二子包)。即通过多电子设备分布式下载该应用的安装包,可以减少安装包的下载时间,提高第一电子设备110下载应用的速度。
下面将以第一电子设备110指示第一电子设备110与第二电子设备120中的至少两个电子设备分布式下载该应用的第一子包为例进行示例性说明。其中,分布式下载与第一电子设备110对应的第二子包以及分布式下载该应用的安装包,可以参照分布式下载该应用的第一子包的相关内容。
具体地,第一电子设备110可以根据第二电子设备120的数量确定对该应用的第一子包进行分组的所有可能的分组方式,并根据各分组方式分别对该应用的第一子包进行分组,得到各分组方式对应的各子包组。随后,对于每一种分组方式,第一电子设备110可以确定该分组方式对应的所有可能的分布式下载方式。然后,第一电子设备110可以确定各分布式下载方式对应的下载时间,并可以根据下载时间最短的分布式下载方式,确定该应用对应的下载策略,下载策略可以包括下载该应用的第一子包的各电子设备以及各电子设备所需下载的子包。其中,各子包组可以包括一个或者多个第一子包,各分组方式对应的子包组的数量s∈[2,1+n],n为第二电子设备120的数量。
请参阅图6,图6示出了本实施例提供的应用场景示意图二。如图6所示,该应用场景中,第一电子设备110可以为手机,第二电子设备120可以包括智能手表和平板电脑。手机、智能手表和平板电脑分别通过通信网络与云端300通信连接。云端300存储有可应用于手机的通话应用,该通话应用的第一子包R可以包括{R1,R2,R3,R4,R5,R6},且智能手表和平板电脑均未下载该通话应用。
当手机需要下载该通话应用时,手机可以根据第二电子设备120的数量确定对第一子包R进行分组的所有可能的分组方式,并可以根据各分组方式分别对第一子包R进行分组,得到各分组方式对应的各子包组。例如,手机可以根据将第一子包R划分为两个子包组的方式得到分组方式A、分组方式B和分组方式C等,以及根据将第一子包R划分为三个子包组的方式得到分组方式D、分组方式E和分组方式F等。示例性的,分组方式A对应的子包组可以包括{R1,R2,R3,R4,R5}和{R6},分组方式B对应的子包组可以包括{R1,R3,R5,R6}和{R2,R4},分组方式C对应的子包组可以包括{R1,R3,R4}和{R2,R5,R6},分组方式D对应的子包组可以包括{R1,R2}、{R3,R4}和{R5,R6},分组方式E对应的子包组可以包括{R1,R2,R3}、{R4,R5}和{R6},分组方式F对应的子包组可以包括{R1,R3,R4,R6}、{R2}和{R5},等等。
对于每一种分组方式,手机可以确定该分组方式对应的所有可能的分布式下载方式,并确定各分布式下载方式对应的下载时间。例如,对于上述的分组方式C,手机可以确定分布式下载方式一为:手机下载子包组{R1,R3,R4},智能手表下载子包组{R2,R5,R6};分布式下载方式二为;手机下载子包组{R1,R3,R4},平板电脑下载子包组{R2,R5,R6};分布式下载方式三为:手机下载子包组{R2,R5,R6},智能手表下载{R1,R3,R4};分布式下载方式四为:手机下载子包组{R2,R5,R6},平板电脑下载子包组{R1,R3,R4};分布式下载方式五为:智能手表下载子包组{R1,R3,R4},平板电脑下载子包组{R2,R5,R6};分布式下载方式六为:智能手表下载子包组{R2,R5,R6},平板电脑下载子包组{R1,R3,R4}。具体地,分布式下载方式一对应的下载时间T1=max(TI11,TW12+TW13),TI11为手机从云端300下载第一子包{R1,R3,R4}的时间,TW12为智能手表从云端300下载第一子包{R2,R5,R6}的时间,TW13为智能手表将第一子包{R2,R5,R6}传输给手机的时间。分布式下载方式五对应的下载时间T5=max(TW51+TW52,TP53+TP54),TW51为智能手表从云端300下载第一子包{R1,R3,R4}的时间,TW52为智能手表将第一子包{R1,R3,R4}传输给手机的时间,TP53为平板电脑从云端300下载第一子包{R2,R5,R6}的时间,TP54为平板电脑将第一子包{R2,R5,R6}传输给手机的时间。其中,分布式下载方式二对应的下载时间、分布式下载方式三对应的下载时间、分布式下载方式四对应的下载时间与分布式下载方式一对应的下载时间的确定原理相同,分布式下载方式五对应的下载时间与分布式下载方式六对应的下载时间的确定原理相同,在此不再赘述。
随后,手机可以获取下载时间最短的分布式下载方式,并根据该分布式下载方式来进行第一子包的下载。假设,在所有的分布式下载方式中,上述的分布式下载方式四对应的下载时间最短,则手机可以确定由手机从云端300下载第一子包{R2,R5,R6},同时由平板电脑从云端300下载第一子包{R1,R3,R4}。此时,手机可以向平板电脑发送下载指令,以指示平板电脑从云端300下载该应用的第一子包R1、第一子包R3和第一子包R4,并将所下载的第一子包R1、第一子包R3和第一子包R4发送给手机。平板电脑接收到下载指令时,可以向云端300发送第一下载请求,以请求下载第一子包R1、第一子包R3和第一子包R4。同时,手机自己可以向云端300发送第二下载请求,以请求下载该应用的第一子包R2、第一子包R5和第一子包R6。
由于第一子包的大小差异较大,且各电子设备的下载速度一般需要一定的缓存时间才能达到最优的稳定速度,为保证下载稳定性,可以对第一子包进行分级分配下载。即本实施例中,在对该应用的第一子包进行分组之前,第一电子设备110可以先根据第一子包的大小对第一子包进行分级,即将第一子包划分为预设层级,每一层级中可以包括一个或者多个第一子包。然后,第一电子设备110可以将每一个层级中的所有第一子包作为一个整体来进行第一子包的分组,得到各分组方式对应的各子包组,各子包组可以包括至少一个层级中的所有第一子包。对于每一种分组方式,第一电子设备110可以确定该分组方式对应的所有可能的分布式下载方式。随后,第一电子设备110可以确定各分布式下载方式对应的下载时间,并根据下载时间最短的分布式下载方式,确定该应用对应的下载策略,即确定下载该应用的第一子包的各电子设备以及各电子设备所需下载的子包。
可以理解的是,第一电子设备110可以根据实际情况来进行预设层级的确定,例如,第一电子设备110可以按照(0,volume],(volume,10*volume]和(10*volume,∞]将该应用的第一子包划分为三个层级,volume可以为第一电子设备110达到最优的稳定速度时,已下载的子包大小。
需要说明的是,第一电子设备110在确定分布式下载方式对应的下载时间后,可以获取第一电子设备110直接下载该应用的第一子包所需的下载时间,以及指示一个第二电子设备120下载第一子包所需的最短的下载时间,并可以根据这多个下载时间来确定最终下载第一子包的电子设备。例如,第一电子设备可以根据这多个下载时间中的最短时间,来确定最终下载第一子包的电子设备。
二、存在第二电子设备120已下载该应用
本实施例中,当存在第二电子设备120已下载该应用(为方便描述,下面将已下载该应用的第二电子设备120称为第三电子设备)时,第一电子设备110可以根据第三电子设备所下载的安装包是否包括与第一电子设备110对应的第二子包来进行该应用的下载。
(一)第三电子设备所下载的安装包中不包括与第一电子设备110对应的第二子包
具体地,各电子设备下载应用时,可以仅下载该应用的第一子包以及与该电子设备对应的第二子包。因此,当第一电子设备110下载该应用时,若存在第三电子设备,表明第三电子设备具有该应用的第一子包。也就是说,云端300具有与第一电子设备110对应的第二子包,第三电子设备和云端300均具有该应用的第一子包。此时,第一电子设备110可以从云端300下载与第一电子设备110对应的第二子包,并可以从云端300和/或第三电子设备下载该应用的第一子包。其中,第一电子设备110仅从云端300下载该应用的第一子包以及与第一电子设备110对应的第二子包的内容可以参照前述第一电子设备110从云端300下载该应用的完整安装包的描述。
示例性的,第一电子设备110可以从第三电子设备下载该应用的第一子包,并可以同时从云端300下载与第一电子设备110对应的第二子包。在此,当第三电子设备为一个时,第一电子设备110可以从这一个第三电子设备下载第一子包。当第三电子设备为多个时,第一电子设备110可以确定下载时间最短的第三电子设备,并从下载时间最短的第三电子设备下载第一子包。此时的下载时间是指第一电子设备110从第三电子设备下载全部第一子包所需的时间。其中,此时的下载时间以及后续所述的下载时间均可以参照前述第一时间的确定方式确定,在此不再赘述。
或者,第一电子设备110可以从云端300下载与第一电子设备110对应的第二子包,并可以从云端300和第三电子设备分布式下载该应用的第一子包。具体地,第一电子设备110可以根据第三电子设备的数量确定对第一子包进行分组的所有可能的分组方式,并可以根据各分组方式分别对第一子包进行分组,得到各分组方式对应的各子包组。其中,各分组方式对应的子包组的数量s∈[2,1+n],n为第三电子设备的数量。对于每一种分组方式,第一电子设备110可以确定该分组方式对应的所有可能的分布式下载方式。然后,第一电子设备110可以确定各分布式下载方式对应的下载时间,并根据下载时间最短的分布式下载方式来进行该应用的下载。
类似的,第一电子设备110在确定分布式下载方式对应的下载时间后,可以获取第一电子设备110直接下载该应用的第二子包所需的下载时间,以及指示一个第二电子设备120下载第二子包所需的最短的下载时间,并可以根据这多个下载时间来确定最终下载第二子包的电子设备。例如,第一电子设备可以根据这多个下载时间中的最短时间,来确定最终下载第二子包的电子设备。
其中,参照前述描述可知,分布式下载方式对应的下载时间为第一电子设备110从该分布式下载方式涉及的设备分别下载部分第一子包所需时间的最大值。由于,第一电子设备110需要从云端300下载与第一电子设备110对应的第二子包,因此,当分布式下载方式中涉及从云端300下载第一子包时,第一电子设备110从云端300下载第一子包的时间可以包括第一电子设备110从云端300下载与第一电子设备110对应的第二子包的时间和从云端300下载部分第一子包的时间。
请参阅图7,图7示出了本实施例提供的应用场景示意图三。在该应用场景中,手机需要下载通话应用,该通话应用的第一子包R可以包括{R1,R2,R3,R4,R5,R6},且手机确定智能手表和平板电脑均已下载该通话应用。即智能手表中具有该通话应用的第一子包{R1,R2,R3,R4,R5,R6}和第二子包B,平板电脑中具有该通话应用的第一子包{R1,R2,R3,R4,R5,R6}和第二子包D。
此时,手机可以确定从智能手表下载第一子包{R1,R2,R3,R4,R5,R6}的时间TW和从平板电脑下载第一子包{R1,R2,R3,R4,R5,R6}的时间TP,假设手机确定TW<TP,如图7中的(a)所示,手机可以向云端300发送第一下载请求,以请求下载与手机对应的第二子包A。同时,手机可以向从智能手表发送第二下载请求,以请求下载第一子包{R1,R2,R3,R4,R5,R6}。
或者,手机可以确定对第一子包进行分组的所有可能的分组方式,并根据各分组方式分别对第一子包{R1,R2,R3,R4,R5,R6}进行分组,得到各分组方式对应的各子包组。例如手机根据将第一子包{R1,R2,R3,R4,R5,R6}划分为两个子包组的方式,可以得到分组方式d和分组方式e等,根据将第一子包{R1,R2,R3,R4,R5,R6}划分为三个子包组的方式,可以得到分组方式f和分组方式g等。其中,分组方式d对应的子包组可以包括{R1,R2,R4}和{R3,R5,R6},分组方式e对应的子包组可以包括{R1,R4,R5,R6}和{R2,R3},分组方式f对应的子包组可以包括{R1,R2,R3}、{R4,R5}和{R6},分组方式g对应的子包组可以包括{R2,R3}、{R1,R5}和{R4,R6}。
对于每一种分组方式,手机可以确定该分组方式对应的所有可能的分布式下载方式,并确定各分布式下载方式对应的下载时间。例如,对于分组方式d,手机确定分布式下载方式一可以为:手机从智能手表下载子包组{R1,R2,R4},并同时从平板电脑下载{R3,R5,R6};分布式下载方式二可以为:手机从智能手表下载{R3,R5,R6},并同时从平板电脑下载{R1,R2,R4};分布式下载方式三可以为:手机从云端下载子包组{R1,R2,R4},并同时从智能手表下载{R3,R5,R6};分布式下载方式四可以为:手机从云端下载{R3,R5,R6},并同时从平板电脑下载{R1,R2,R4}。其中,分布式下载方式一对应的下载时间=max(TW,TP),此时TW为手机从智能手表下载第一子包{R1,R2,R4}的时间,TP为手机从平板电脑下载第一子包{R3,R5,R6}的时间。分布式下载方式三对应的下载时间=max(TC,TW),此时TC为手机从云端下载第一子包{R1,R2,R4}和第二子包A的时间,TW为手机从智能手表下载第一子包{R3,R5,R6}的时间。应理解,分布式下载方式二对应的下载时间与分布式下载方式一对应的下载时间的确定原理相同,分布式下载方式四对应的下载时间与分布式下载方式三对应的下载时间的确定原理相同。
然后,手机可以根据下载时间最短的分布式下载方式来进行该应用的下载。假设手机确定上述的分布式下载方式二对应的下载时间最短,此时,如图7中的(b)所示,手机可以向云端300发送第一下载请求,以请求下载第二子包A。同时,手机可以向智能手表发送第二下载请求,以请求下载第一子包{R3,R5,R6},以及可以向平板电脑发送第三下载请求,以请求下载第一子包{R1,R2,R4}。
(二)第三电子设备所下载的安装包中包括与第一电子设备110对应的第二子包
在此,当第三电子设备与第一电子设备110为同类型且特性相同的电子设备,或者当各电子设备下载该应用时,可以下载该应用的全部安装包(即该应用的第一子包以及与各类型的电子设备对应的第二子包)时,若存在第三电子设备,表明第三电子设备和云端300均具有该应用的第一子包以及与第一电子设备110对应的第二子包。此时,第一电子设备110可以从云端300和/或第三电子设备下载该应用的第一子包,并可以从云端300和/或第三电子设备下载与第一电子设备110对应的第二子包。
其中,第一电子设备110从云端300或第三电子设备下载该应用的第一子包,并从云端300和第三电子设备分布式下载与第一电子设备110对应的第二子包,以及第一电子设备110从云端300和第三电子设备分布式下载该应用的第一子包,并从云端300或第三电子设备下载与第一电子设备110对应的第二子包的原理与前述第一电子设备110从云端300下载与第一电子设备110对应的第二子包,并从云端300和第三电子设备分布式下载该应用的第一子包的原理基本相同,具体内容可以参照前述描述。
以下结合具体应用场景对第一电子设备110从云端300和第三电子设备分布式下载与第一电子设备110对应的第二子包,并从云端300和第三电子设备分布式下载该应用的第一子包的过程进行示例性说明。
请参阅图8,图8示出了本实施例提供的应用场景示意图四。在该应用场景中,手机需要下载通话应用,该通话应用的第一子包R可以包括{R1,R2,R3,R4,R5,R6},与手机对应的第二子包可以包括{A1,A2,A3,A4},且手机确定智能手表、平板电脑和智慧大屏均已下载该通话应用,即智能手表、平板电脑和智慧大屏中均具有该通话应用的第一子包{R1,R2,R3,R4,R5,R6}和第二子包{A1,A2,A3,A4}。
此时,手机可以确定对该通话应用的全部子包{R1,R2,R3,R4,R5,R6,A1,A2,A3,A4}进行分组的所有可能的分组方式,并可以根据各分组方式分别对该应用的全部子包{R1,R2,R3,R4,R5,R6,A1,A2,A3,A4}进行分组,得到各分组方式对应的各子包组。
例如,手机根据将全部子包{R1,R2,R3,R4,R5,R6,A1,A2,A3,A4}划分为两个子包组的方式,可以得到分组方式F1和第一分组方式F2,等等,划分为三个子包组的方式,可以得到分组方式F3和分组方式F4,等等,以及划分为四个子包组的方式,可以得到分组方式F5和分组方式F6,等等。假设,分组方式F1对应的子包组可以包括{R1,R2,R3,A1,A2}和{R4,R5,R6,A3,A4},分组方式F2对应的子包组可以包括{R1,R2,R3,R4}和{R5,R6,A1,A2,A3,A4},分组方式F3对应的子包组可以包括{R1,R2,A1,A2}、{R3,R4,A3}和{R5,R6,A4},分组方式F4对应的子包组可以包括{R1,R2,R3}、{R4,R5,R6}和{A1,A2,A3,A4},分组方式F5对应的子包组可以包括{R1,R2,A2}、{R3,R4}、{R5,R6}和{A1,A3,A4},分组方式F6对应的子包组包括{R1,R2,R3}、{R4,R5,R6}、{A1,A2}和{A3,A4}。
对于每一种分组方式,第一电子设备110可以确定分组方式对应的所有可能的分布式下载方式,并确定各分布式下载方式对应的下载时间。例如,对于分组方式F6,手机可以确定分布式下载方式一可以为:手机从云端下载{R1,R2,R3},从智能手表下载{R4,R5,R6},从平板电脑下载{A1,A2}以及从智慧大屏下载{A3,A4};分布式下载方式二可以为:手机从智能手表下载{R1,R2,R3},从平板电脑下载{R4,R5,R6},从云端下载{A1,A2}以及从智慧大屏下载{A3,A4};分布式下载方式三可以为:手机从云端下载{R1,R2,R3},从平板电脑下载{R4,R5,R6},从智慧大屏下载{A1,A2}以及从智能手表下载{A3,A4};分布式下载方式四可以为:手机从智慧大屏下载{R1,R2,R3},从云端下载{R4,R5,R6},从平板电脑下载{A1,A2}以及从智能手表下载{A3,A4},等等。其中,分布式下载方式一对应的下载时间=max(TC,TW,TP,TS),此时TC为手机从云端下载{R1,R2,R3}的时间,TW为手机从智能手表下载{R4,R5,R6}的时间,TP为手机从平板电脑下载{A1,A2}的时间,TS为手机从智慧大屏下载{A3,A4}的时间。应理解,分布式下载方式二、三、四对应的下载时间的确定与之类似。
然后,手机可以根据下载时间最短的分布式下载方式来进行该应用的下载。假设手机确定上述的分布式下载方式四对应的下载时间最短,此时,如图8所示,手机可以向智慧大屏发送第一下载请求,以请求下载{R1,R2,R3}。同时,手机可以向云端300发送第二下载请求,以请求下载{R4,R5,R6},以及向平板电脑发送第三下载请求,以请求下载{A1,A2},以及向智能手表发送第四下载请求,以请求下载{A3,A4}。
需要说明的是,第一电子设备110在确定分布式下载方式对应的下载时间后,可以获取第一电子设备110直接从云端300或任一第三电子设备下载该应用的全部安装包所需的下载时间,并可以根据这多个下载时间来确定最终下载的下载方式。例如,第一电子设备可以根据这多个下载时间中的最短时间,来确定最终下载的下载方式。
可以理解的是,在存在第三电子设备时,第一电子设备110也可以指示至少一个第二电子设备120从云端300和/或第三电子设备下载该应用的第一子包和/或第二子包,并将所下载的第一子包和/或第二子包发送给第一电子设备110。其中,第一电子设备110指示第二电子设备120从云端300和/或第三电子设备下载该应用的第一子包和/或第二子包的内容可以参照前述描述,在此不再赘述。
下面将对本实施例提供的应用下载安装方法进行示例性说明。请参阅图9,图9示出了本实施例提供的应用分包下载方法的示意性流程图。如图9所示,当第一电子设备110需要下载某一应用时,第一电子设备110可以向云端300发送第一查询请求,以请求查询该应用的子包信息,例如第一电子设备110可以调用pagequery接口,向云端300发送第一查询请求。云端300接收到第一查询请求之后,可以查询该应用的子包信息,并将所查询到的子包信息以数组形式(即{子包1、子包2、……、子包n})返回第一电子设备110。同时,第一电子设备110可以向各第二电子设备120发送第二查询请求,以请求查询各第二电子设备120中该应用的相关信息,例如第一电子设备110可以调用queryDevicesFa接口,向各第二电子设备120发送第二查询请求。各第二电子设备120接收到第二查询请求之后,可以查询各第二电子设备中该应用的相关信息,并将查询结果返回给第一电子设备110。随后,第一电子设备110可以根据各第二电子设备120返回的查询结果以及云端300返回的子包信息,确定该应用的下载策略,并根据该下载策略来进行该应用的下载。其中,下载策略指示第一电子设备110如何下载该应用的第一子包以及如何下载与第一电子设备110对应的第二子包。例如,下载策略可以为第一电子设备110从云端300下载与第一电子设备110对应的第二子包,并同时从第二电子设备120下载该应用的第一子包。
示例性的,第一电子设备110中设置有服务中心,服务中心可以包括服务管理模块、端侧数据管理模块以及策略调用模块。当第一电子设备110需要下载某一应用时,服务管理模块可以调用pagequery接口向云端300发送第一查询请求,并接收云端300所返回的子包信息。同时,服务管理模块还可以调用端侧数据管理模块中的queryDevicesFa接口向各第二电子设备120发送第二查询请求。端侧数据管理模块可以存储各第二电子设备120返回的查询结果。另外,服务管理模块还可以指示策略调用模块根据端侧数据管理模块中的查询结果以及服务管理模块中的子包信息确定该应用的下载策略,并将所确定的下载策略发送给服务管理模块。服务管理模块还可以根据该应用的下载策略来进行该应用的下载。
本实施例中,第一子包和第二子包的结构均可以为包头、序号以及具体内容。其中,包头中记录有该子包的类型(例如是第一子包,还是第二子包)和所属的应用。因此,第一电子设备110获取各子包后,可以根据包头中的信息找到该应用所对应的所有子包,并根据子包的序号对该应用的所有子包进行拼接,从而得到该应用的完整安装包。
本实施例中,将应用的安装包拆分成多个子包,云端和已下载该应用的电子设备可以存储有该应用的子包。因此,当第一电子设备需要下载应用时,第一电子设备可以同时从云端和已下载该应用的电子设备下载该应用的各子包,以减少第一电子设备下载该应用的安装包的时间,提高第一电子设备下载应用的速度,提升用户体验。
【实施例二】
以下将结合具体应用场景对本申请实施例二提供的应用老化方法进行详细说明。与实施例一相同,本实施例中,任一应用的安装包可以包括第一子包以及分别与各类型的电子设备对应的第二子包。
本实施例中,当某一电子设备(以下称为第一电子设备)中的某一应用满足预设老化条件时,第一电子设备可以分别确定该应用的各个子包对应的下载时间,并根据各个子包对应的下载时间对该应用进行老化。其中,预设老化条件可以为未被使用的连续时长达到预设时长阈值(例如30天),或者可以为接收到删除或卸载指令。该应用的子包可以包括该应用的第一子包以及与第一电子设备对应的第二子包。任一子包对应的下载时间为第一电子设备再次下载该子包所需的时间。
对于任一子包Ai,第一电子设备可以确定各第二电子设备是否具有子包Ai。其中,第二电子设备为与第一电子设备通信连接的电子设备。当存在第二电子设备具有子包Ai时,第一电子设备可以确定从云端下载子包Ai的第一时间,以及分别从具有子包Ai的第二电子设备(为描述方便,以下将具有子包Ai的第二电子设备称为第三电子设备)下载子包Ai的各第二时间,并可以将第一时间与各第二时间中的最小值确定为子包Ai对应的下载时间Value(Ai)。具体地,第一电子设备可以根据下述公式确定第一时间和第二时间:
Ti,c=tc,delay+max(sizeof(Ai)–volumec,0)/vc,max;
Ti,j=tj,delay+max(sizeof(Ai)–volumej,0)/vj,max;
其中,Ti,c为从云端下载子包Ai的第一时间,tc,delay为从云端下载子包Ai中,第一电子设备达到稳定速度vc,max所需的时间,volumec为在tc,delay时间,第一电子设备从云端下载的子包大小,sizeof(Ai)为子包Ai的大小,Ti,j为从第j个第三电子设备下载子包Ai的第二时间,tj,delay为从第j个第三电子设备下载子包Ai中,第一电子设备达到稳定速度vj,max所需的时间,volumej为在tj,delay时间,第一电子设备从第j个第三电子设备下载的子包大小,1≤j≤L,L为第三电子设备的数量。
当各第二电子设备均不具有子包Ai时,表明只有云端存储有子包Ai,即第一电子设备只能从云端下载子包Ai。此时,第一电子设备可以将从云端下载子包Ai的第一时间确定为子包Ai对应的下载时间Value(Ai),即Value(Ai)=Ti,c=tc,delay+max(sizeof(Ai)–volumec,0)/vc,max。
本实施例中,在确定各个子包对应的下载时间之后,第一电子设备可以保留下载时间最长的M个子包,并将该应用的其他子包进行老化,即将下载速度较慢的部分子包进行保留,使得再次启动该应用时,可以减少该应用的下载时间。其中,M可以由用户自定义设置,也可以由第一电子设备根据实际情况具体确定。
在一种可能的实现方式中,第一电子设备保留某一子包可以是将该子包保留预设时间。也就是说,在确定各个子包对应的下载时间之后,第一电子设备可以保留下载时间最长的M个子包,并将该应用的其他子包进行老化。后续,经过预设时间后,若第一电子设备仍为使用该应用,第一电子设备则可以将保留的M个子包中的一个或者多个进行老化。其中,预设时间可以由技术人员根据实际场景具体设置。
示例性的,第一电子设备可以根据各个子包对应的下载时间对子包进行降序排列,得到排列数组。随后,第一电子设备可以根据卸载应用时,第一电子设备所允许残留的最大数据量和降序排列后的数组来确定M,具体地:
其中,maxSize为卸载应用时,第一电子设备所允许残留的最大数据量,为排列数组中的第l个子包的大小,N为子包的数量。卸载应用时,第一电子设备所允许残留的最大数据量可以由用户自定义设置,也可以由第一电子设备默认设置,本实施例对此不作具体限定。
可以理解的是,当M不存在时,即当该应用的各子包均大于maxSize时,第一电子设备则可以老化该应用的所有子包。
请参阅图10,图10示出了本实施例提供的应用老化方法的应用场景示意图。该应用场景中可以包括手机1010、智能手表1020、平板电脑1030和云端1040。其中,手机1010分别通过通信网络与智能手表1020、平板电脑1030、云端1040通信连接。手机1010下载有通话应用,该通话应用可以包括的第一子包{R1,R2,R3,R4},以及与手机1010对应的第二子包{A1,A2,A3}。
当手机1010确定该通话应用连续30天未被使用时,手机1010可以确定该通话应用满足预设老化条件,即确定需要对该通话应用进行老化,此时,手机1010可确定第一子包R1对应的下载时间TR1,第一子包R2对应的下载时间TR2,第一子包R3对应的下载时间TR3,第一子包R4对应的下载时间TR4,第二子包A1对应的下载时间TA1,第二子包A2对应的下载时间TA2以及第二子包A3对应的下载时间TA3。假设手机1010确定智能手表1020和平板电脑1030均具有第一子包R1、第一子包R2和第一子包R3,智能手表1020具有第一子包R4和第二子包A1。
对于第一子包R1,手机1010可以获取从云端1040下载第一子包R1的时间TCR1、从智能手表1020下载第一子包R1的时间TIR1,以及从平板电脑1030下载第一子包R1的时间TPR1,假设手机1010确定TCR1<TPR1<TIR1,则手机1010可以确定第一子包R1对应的下载时间TR1=TCR1。
对于第一子包R4,手机1010可以获取从云端300下载第一子包R4的时间TCR4和从智能手表1020下载第一子包R4的时间TIR4,假设手机确定TIR4<TCR4,则手机1010可以确定第一子包R4对应的下载时间TR4=TIR4。
对于第二子包A2,手机1010可以获取从云端300下载第二子包A2的时间TCA2,并可以确定第二子包A2对应的下载时间TA2=TCA2。
假设手机1010确定TR1>TR3>TA1>TR2>TA3>TA2>TR4,且M=3时,手机1010可以仅老化第一子包R2、第一子包R4、第二子包A2和第二子包A3,以保留第一子包R1、第一子包R3和第二子包A1。
本实施例中,将应用的安装包拆分成多个子包,在第一电子设备需要老化应用时,第一电子设备可以确定再次下载该应用的各个子包的时间,并根据各个子包的下载时间对该应用的部分子包进行老化,保留该应用的部分子包,使得在下一次需要使用该应用时,第一电子设备仅需要下载该应用的部分子包,而不需要下载该应用的整个安装包,可以减少应用的下载时间,提高应用再次启动的速度,提升用户体验。
应理解,上述实施例中各步骤的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本申请实施例的实施过程构成任何限定。
对应于上文实施例一所述的应用下载安装方法,本申请实施例还提供了一种应用下载安装装置,该应用下载安装装置的各个模块可以对应实现实施例一中的应用下载安装方法的各个步骤。
对应于上文实施例二所述的应用老化方法,本申请实施例还提供了一种应用老化装置,该应用老化装置的各个模块可以对应实现实施例二中的应用老化方法的各个步骤。
需要说明的是,上述装置/单元之间的信息交互、执行过程等内容,由于与本申请方法实施例基于同一构思,其具体功能及带来的技术效果,具体可参见方法实施例部分,此处不再赘述。
所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,仅以上述各功能单元、模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能单元、模块完成,即将所述装置的内部结构划分成不同的功能单元或模块,以完成以上描述的全部或者部分功能。实施例中的各功能单元、模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中,上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。另外,各功能单元、模块的具体名称也只是为了便于相互区分,并不用于限制本申请的保护范围。上述系统中单元、模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
本申请实施例还提供了一种电子设备,所述电子设备包括至少一个存储器、至少一个处理器以及存储在所述至少一个存储器中并可在所述至少一个处理器上运行的计算机程序,所述处理器执行所述计算机程序时,使所述电子设备实现上述任意各个方法实施例中的步骤。示例性的,所述电子设备的结构可以如图1所示。
本申请实施例还提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被计算机执行时,使所述计算机实现上述任意各个方法实施例中的步骤。
本申请实施例提供了一种计算机程序产品,当计算机程序产品在电子设备上运行时,使得电子设备实现上述任意各个方法实施例中的步骤。
所述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读存储介质中。基于这样的理解,本申请实现上述实施例方法中的全部或部分流程,可以通过计算机程序来指令相关的硬件来完成,所述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,所述计算机程序包括计算机程序代码,所述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。所述计算机可读存储介质至少可以包括:能够将计算机程序代码携带到装置/电子设备的任何实体或装置、记录介质、计算机存储器、只读存储器(read-only memory,ROM)、随机存取存储器(random accessmemory,RAM)、电载波信号、电信信号以及软件分发介质。例如U盘、移动硬盘、磁碟或者光盘等。在某些司法管辖区,根据立法和专利实践,计算机可读存储介质不可以是电载波信号和电信信号。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。
在本申请所提供的实施例中,应该理解到,所揭露的装置/电子设备和方法,可以通过其它的方式实现。例如,以上所描述的装置/电子设备实施例仅仅是示意性的,例如,所述模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通讯连接可以是通过一些接口,装置或单元的间接耦合或通讯连接,可以是电性,机械或其它的形式。
所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
以上所述实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的精神和范围,均应包含在本申请的保护范围之内。
Claims (18)
1.一种应用下载安装方法,其特征在于,应用于第一电子设备,所述方法包括:
所述第一电子设备检测到下载第一应用的触发事件,所述第一应用至少包括第一部分和第二部分,所述第一部分包括第一子包,所述第二部分包括第二子包;
所述第一电子设备从第二设备获取所述第一子包,并从第三设备获取所述第二子包;所述第二设备与所述第三设备不同;
所述第一电子设备根据所述第一部分和所述第二部分,安装所述第一应用。
2.根据权利要求1所述的方法,其特征在于,所述第二设备为用户的第二电子设备,所述第三设备为用户的第三电子设备或服务器。
3.根据权利要求2所述的方法,其特征在于,所述第一电子设备获取的第一子包是所述第二电子设备中存储的,或者,所述第一电子设备获取的第一子包是所述第二电子设备获取的。
4.根据权利要求2或3所述的方法,其特征在于,当所述第三设备为用户的第三电子设备时,所述第一电子设备获取的第二子包是所述第三电子设备中存储的,或者,所述第一电子设备获取的第二子包是所述第三电子设备获取的。
5.根据权利要求1至4中任一项所述的方法,其特征在于,所述第一部分还包括第三子包,所述方法还包括:
所述第一电子设备从第四设备获取所述第三子包,所述第四设备为用户的第四电子设备或服务器。
6.根据权利要求1至5中任一项所述的方法,其特征在于,所述第二部分还包括第四子包,所述方法还包括:
所述第一电子设备从第五设备获取所述第四子包。
7.根据权利要求1至6中任一项所述的方法,其特征在于,所述第一部分是所述第一应用的基础部分;所述第二部分为特性部分,所述第二部分与所述第一电子设备的属性相关;或者,所述第一部分是特性部分,第二部分是基础部分。
8.根据权利要求1至7中任一项所述的方法,其特征在于,在所述第一电子设备从第二设备获取所述第一子包,并从第三设备获取所述第二子包之前,所述方法还包括:
所述第一电子设备确定下载所述第一子包的第一下载时间,以及下载所述第二子包的第二下载时间;
所述第一电子设备根据所述第一下载时间和所述第二下载时间确定下载策略,所述下载策略包括:所述第一电子设备从第二设备获取所述第一子包,并从第三设备获取所述第二子包。
9.根据权利要求8所述的方法,其特征在于,所述第一电子设备确定下载所述第一子包的第一下载时间,包括:
所述第一电子设备获取所述第一子包的大小和所述第一子包对应的第一速度,所述第一子包对应的第一速度包括所述第一电子设备从存储有所述第一子包的第六设备下载所述第一子包的速度,或者包括第七设备下载所述第一子包的速度和所述第七设备将所述第一子包传输给所述第一电子设备的速度;
所述第一电子设备根据所述第一子包的大小和所述第一速度确定下载所述第一子包的第一下载时间。
10.根据权利要求1至9中任一项所述的方法,其特征在于,在所述第一电子设备根据所述第一部分和所述第二部分,安装所述第一应用之后,所述方法还包括:
所述第一电子设备确定下载所述第一子包的第三下载时间和下载所述第二子包的第四下载时间;
所述第一电子设备根据所述第三下载时间和所述第四下载时间确定待老化的目标子包,并对所述目标子包进行老化,所述目标子包为所述第一子包,或者所述目标子包为所述第二子包,所述对所述目标子包进行老化包括删除所述目标子包或者卸载所述目标子包。
11.根据权利要求10所述的方法,其特征在于,当所述目标子包为所述第一子包时,所述第一电子设备对所述目标子包进行老化,包括:
所述第一电子设备对所述第一子包进行老化,并保留所述第二子包;
当所述目标子包为所述第二子包时,所述第一电子设备对所述目标子包进行老化,包括:
所述第一电子设备对所述第二子包进行老化,并保留所述第一子包。
12.一种应用老化方法,其特征在于,应用于第一电子设备,所述方法包括:
所述第一电子设备确定第一应用,所述第一应用包括第一子包和第二子包;
所述第一电子设备对所述第一子包和所述第二子包进行不同的处理,所述第一电子设备对所述第一子包和所述第二子包进行不同的处理包括:所述第一电子设备对所述第一子包进行老化,并保留所述第二子包;或者,所述第一电子设备在第一时间对所述第一子包进行老化,并在第二时间对所述第二子包进行老化;所述第一电子设备对所述第一子包进行老化包括所述第一电子设备删除所述第一子包或者卸载所述第一子包。
13.根据权利要求12所述的方法,其特征在于,所述第一电子设备对所述第一子包和所述第二子包进行不同的处理,包括:
所述第一电子设备获取所述第一子包的第一下载时间,以及获取所述第二子包的第二下载时间;
所述第一电子设备根据所述第一下载时间和所述第二下载时间确定待老化的目标子包,并对所述目标子包进行老化,所述目标子包为所述第一子包,或者所述目标子包为所述第二子包。
14.根据权利要求13所述的方法,其特征在于,当所述目标子包为所述第一子包时,所述第一电子设备对所述目标子包进行老化,包括:
所述第一电子设备对所述第一子包进行老化,并保留所述第二子包;
当所述目标子包为所述第二子包时,所述第一电子设备对所述目标子包进行老化,包括:
所述第一电子设备对所述第二子包进行老化,并保留所述第一子包。
15.根据权利要求13或14所述的方法,其特征在于,所述第一电子设备获取第一子包的第一下载时间,包括:
所述第一电子设备获取所述第一子包的大小和所述第一子包对应的第一速度,所述第一子包对应的第一速度包括所述第一电子设备从存储有所述第一子包的第二设备下载所述第一子包的速度,或者包括第三设备下载所述第一子包的速度和所述第三设备将所述第一子包传输给所述第一电子设备的速度;
所述第一电子设备根据所述第一子包的大小和所述第一速度确定所述第一子包的第一下载时间。
16.根据权利要求12至15中任一项所述的方法,其特征在于,所述第一电子设备确定第一应用包括:
所述第一电子设备获取第二应用的第一时长,所述第一时长为所述第二应用未被使用的连续时长,所述第二应用为所述第一电子设备中的任一应用;
当所述第一时长大于或等于预设时长阈值时,所述第一电子设备确定所述第二应用为所述第一应用。
17.一种电子设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时,使所述电子设备实现如权利要求1至11中任一项所述的应用下载安装方法,或实现如权利要求12至16中任一项所述的应用老化方法。
18.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被计算机执行时,使所述计算机实现如权利要求1至11中任一项所述的应用下载安装方法,或实现如权利要求12至16中任一项所述的应用老化方法。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111280483.1A CN116074305A (zh) | 2021-10-30 | 2021-10-30 | 应用下载安装方法、应用老化方法及电子设备 |
PCT/CN2022/114539 WO2023071472A1 (zh) | 2021-10-30 | 2022-08-24 | 应用下载安装方法、应用老化方法及电子设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111280483.1A CN116074305A (zh) | 2021-10-30 | 2021-10-30 | 应用下载安装方法、应用老化方法及电子设备 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN116074305A true CN116074305A (zh) | 2023-05-05 |
Family
ID=86160138
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111280483.1A Pending CN116074305A (zh) | 2021-10-30 | 2021-10-30 | 应用下载安装方法、应用老化方法及电子设备 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN116074305A (zh) |
WO (1) | WO2023071472A1 (zh) |
Family Cites Families (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6594784B1 (en) * | 1999-11-17 | 2003-07-15 | International Business Machines Corporation | Method and system for transparent time-based selective software rejuvenation |
US20060271926A1 (en) * | 2005-05-31 | 2006-11-30 | Microsoft Corporation | Split download for electronic software downloads |
CN100435106C (zh) * | 2006-11-21 | 2008-11-19 | 西安交通大学 | 应用服务器的分级再生方法 |
KR101284551B1 (ko) * | 2011-04-21 | 2013-07-11 | (주)지온네트웍스 | 휴대단말기간의 어플리케이션 이체설치 방법 |
CN107608722B (zh) * | 2017-09-19 | 2020-12-01 | 北京安博通科技股份有限公司 | 应用程序下载方法及装置 |
CN110166543B (zh) * | 2019-05-16 | 2020-08-28 | 腾讯科技(深圳)有限公司 | 应用程序处理方法、装置和计算机设备 |
CN110780887A (zh) * | 2019-09-23 | 2020-02-11 | 连尚(新昌)网络科技有限公司 | 一种提供应用安装包的方法与设备 |
-
2021
- 2021-10-30 CN CN202111280483.1A patent/CN116074305A/zh active Pending
-
2022
- 2022-08-24 WO PCT/CN2022/114539 patent/WO2023071472A1/zh unknown
Also Published As
Publication number | Publication date |
---|---|
WO2023071472A1 (zh) | 2023-05-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN114449599B (zh) | 基于电子设备位置的网络链路切换方法和电子设备 | |
CN114079893B (zh) | 蓝牙通信方法、终端设备及计算机可读存储介质 | |
CN115696483B (zh) | 基于电子设备状态的网络链路切换方法和电子设备 | |
WO2021159746A1 (zh) | 文件共享方法、系统及相关设备 | |
CN114095599B (zh) | 消息显示方法和电子设备 | |
CN110636554B (zh) | 数据传输方法及装置 | |
CN113821767A (zh) | 应用程序的权限管理方法、装置和电子设备 | |
WO2021218429A1 (zh) | 应用窗口的管理方法、终端设备及计算机可读存储介质 | |
WO2021169370A1 (zh) | 服务元素的跨设备分配方法、终端设备及存储介质 | |
CN115333941B (zh) | 获取应用运行情况的方法及相关设备 | |
CN111372329A (zh) | 一种连接建立方法及终端设备 | |
CN114995715B (zh) | 悬浮球的控制方法和相关装置 | |
CN113590346B (zh) | 处理业务请求的方法和电子设备 | |
WO2022242412A1 (zh) | 杀应用的方法及相关设备 | |
CN114006698B (zh) | token刷新方法、装置、电子设备及可读存储介质 | |
CN114828098B (zh) | 数据传输方法和电子设备 | |
WO2022062902A1 (zh) | 一种文件传输方法和电子设备 | |
WO2023071472A1 (zh) | 应用下载安装方法、应用老化方法及电子设备 | |
CN116048831B (zh) | 一种目标信号处理方法和电子设备 | |
CN116048594B (zh) | 软件升级方法及相关装置 | |
CN113254409B (zh) | 文件共享方法、系统及相关设备 | |
CN116719376B (zh) | 电压控制方法、装置、设备和存储介质 | |
CN114205318B (zh) | 头像显示方法及电子设备 | |
CN114006976B (zh) | 一种界面显示方法及终端设备 | |
WO2024078315A1 (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 |