CN108762831A - 应用程序预加载方法、装置、存储介质及终端 - Google Patents

应用程序预加载方法、装置、存储介质及终端 Download PDF

Info

Publication number
CN108762831A
CN108762831A CN201810462478.4A CN201810462478A CN108762831A CN 108762831 A CN108762831 A CN 108762831A CN 201810462478 A CN201810462478 A CN 201810462478A CN 108762831 A CN108762831 A CN 108762831A
Authority
CN
China
Prior art keywords
application
program
preloaded applications
applications program
preloaded
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.)
Granted
Application number
CN201810462478.4A
Other languages
English (en)
Other versions
CN108762831B (zh
Inventor
黄粟
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Shanghai Jinsheng Communication Technology Co Ltd
Original Assignee
Guangdong Oppo Mobile Telecommunications Corp Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Guangdong Oppo Mobile Telecommunications Corp Ltd filed Critical Guangdong Oppo Mobile Telecommunications Corp Ltd
Priority to CN201810462478.4A priority Critical patent/CN108762831B/zh
Publication of CN108762831A publication Critical patent/CN108762831A/zh
Application granted granted Critical
Publication of CN108762831B publication Critical patent/CN108762831B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44505Configuring for program initiating, e.g. using registry, configuration files
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44521Dynamic linking or loading; Link editing at or after load time, e.g. Java class loading
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements 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/44Arrangements for executing specific programs
    • G06F9/445Program loading or initiating
    • G06F9/44594Unloading

Abstract

本申请实施例公开了应用程序预加载方法、装置、存储介质及终端。该方法包括:检测到应用预加载事件被触发时,确定待预加载应用程序;开始对待预加载应用程序进行预加载操作;在对待预加载应用程序进行预加载操作的过程中,实时监测前台应用程序的运行状态;当检测到运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作。本申请实施例通过采用上述技术方案,可以在应用程序预加载的过程中兼顾前台应用程序的运行情况,必要时暂停或终止预加载操作,避免对前台应用程序造成过多影响。

Description

应用程序预加载方法、装置、存储介质及终端
技术领域
本申请实施例涉及应用程序加载技术领域,尤其涉及应用程序预加载方法、装置、存储介质及终端。
背景技术
目前,诸如智能手机、平板电脑、笔记本电脑以及智能家电等终端已成为人们日常生活中必不可少的电子设备。随着终端设备不断地智能化,多数终端设备中都装载有操作系统,使得终端设备能够安装丰富多样的应用程序,满足用户不同的需求。
随着终端设备的配置不断提升,多数终端设备中可以安装几十甚至上百个应用程序,而随着应用程序的功能日益丰富,应用程序运行时所需加载的资源也越来越多。当用户选择启动一个应用程序时,终端会对该应用程序启动所需的资源进行加载,待加载完毕后,进入应用程序的初始界面,整个过程通常要花费数秒甚至十几秒的时间,导致应用程序的启动效率较低,亟需改进。
发明内容
本申请实施例提供一种应用程序预加载方法、装置、存储介质及终端,可以优化应用程序的加载方案。
第一方面,本申请实施例提供了一种应用程序预加载方法,包括:
检测到应用预加载事件被触发时,确定待预加载应用程序;
开始对所述待预加载应用程序进行预加载操作;
在对所述待预加载应用程序进行预加载操作的过程中,实时监测前台应用程序的运行状态;
当检测到所述运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作。
第二方面,本申请实施例提供了一种应用程序预加载装置,包括:
应用确定模块,用于在检测到应用预加载事件被触发时,确定待预加载应用程序;
预加载模块,用于开始对所述待预加载应用程序进行预加载操作;
运行状态监测模块,用于在对所述待预加载应用程序进行预加载操作的过程中,实时监测前台应用程序的运行状态;
预加载调整模块,用于在检测到所述运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作。
第三方面,本申请实施例提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如本申请实施例所述的应用程序预加载方法。
第四方面,本申请实施例提供了一种终端,包括存储器,处理器及存储在存储器上并可在处理器运行的计算机程序,所述处理器执行所述计算机程序时实现如本申请实施例所述的应用程序预加载方法。
本申请实施例中提供的应用程序预加载方案,检测到应用预加载事件被触发时,确定待预加载应用程序,开始对待预加载应用程序进行预加载操作,在对待预加载应用程序进行预加载操作的过程中,实时监测前台应用程序的运行状态,当检测到运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作。通过采用上述技术方案,可以在应用程序预加载的过程中兼顾前台应用程序的运行情况,必要时暂停或终止预加载操作,避免对前台应用程序造成过多影响。
附图说明
图1为本申请实施例提供的一种应用程序预加载方法的流程示意图;
图2为本申请实施例提供的一种预加载活动窗口堆栈与显示屏幕显示区域的相对位置关系示意图;
图3为本申请实施例提供的又一种预加载活动窗口堆栈与显示屏幕显示区域的相对位置关系示意图;
图4为本申请实施例提供的一种应用界面迁移示意图;
图5为本申请实施例提供的另一种应用程序预加载方法的流程示意图;
图6为本申请实施例提供的又一种应用程序预加载方法的流程示意图;
图7为本申请实施例提供的一种应用程序预加载装置的结构框图;
图8为本申请实施例提供的一种移动终端的结构示意图;
图9为本申请实施例提供的又一种移动终端的结构示意图。
具体实施方式
下面结合附图并通过具体实施方式来进一步说明本申请的技术方案。可以理解的是,此处所描述的具体实施例仅仅用于解释本申请,而非对本申请的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本申请相关的部分而非全部结构。
在更加详细地讨论示例性实施例之前应当提到的是,一些示例性实施例被描述成作为流程图描绘的处理或方法。虽然流程图将各步骤描述成顺序的处理,但是其中的许多步骤可以被并行地、并发地或者同时实施。此外,各步骤的顺序可以被重新安排。当其操作完成时所述处理可以被终止,但是还可以具有未包括在附图中的附加步骤。所述处理可以对应于方法、函数、规程、子例程、子程序等等。
图1为本申请实施例提供的一种应用程序预加载方法的流程示意图,该方法可以由应用程序预加载装置执行,其中该装置可由软件和/或硬件实现,一般可集成在终端中。如图1所示,该方法包括:
步骤101、检测到应用预加载事件被触发时,确定待预加载应用程序。
示例性的,本申请实施例中的终端可包括手机、平板电脑、笔记本电脑以及智能家电等终端设备。终端中装载有操作系统。
示例性的,应用预加载事件的触发条件可以根据实际情况设置,本申请实施例不作具体限定。例如,可以在检测到用户的动作满足预设条件(如拿起终端、输入屏幕解锁操作或输入终端解锁操作等)时,触发应用预加载事件;或者可以在检测到前台应用程序发生变更时,触发应用预加载事件;或者可以在预加载应用的预测流程结束后,立即(或经过预设时长后)触发应用预加载事件;或者可以定时间隔触发等等。当应用预加载事件被触发后,系统可以通过读取标志位或接收触发指令等方式检测到应用预加载事件已被触发,具体的检测方式本申请实施例也不做限定。
示例性的,待预加载的应用程序可以理解为用户可能即将打开的应用程序,可以是预先设置好的固定的应用程序,也可以是采用一定的方式预测出来的应用程序等。待预加载的应用程序可以包括一个或多个。
可选的,可采用预测模型对待预加载的应用程序进行预测。该预测模型可以是机器学习模型,所采用的算法可以包括循环神经网络(Recurrent neural networks,RNN)、长短期记忆(Long Short-Term Memory,LSTM)网络、门限循环单元、简单循环单元、自动编码器、决策树、随机森林、特征均值分类、分类回归树、隐马尔科夫、K最近邻(k-NearestNeighbor,KNN)算法、逻辑回归模型、贝叶斯模型、高斯模型以及KL散度(Kullback–Leibler divergence)等等。
可选的,可在用户使用终端的过程中,采集训练样本,采用训练样本对预设初始模型进行训练,最终得到用于预测待预加载的应用程序的预测模型。示例性的,训练样本中包含的元素可包括应用程序被打开的时间序列或次序序列;可包括应用程序被打开的时间、地点以及频次等;可包括终端的运行状态,如移动数据网络的开关状态、无线热点的连接状态、所连接的无线热点的身份信息、当前运行的应用程序、上一个前景应用程序、当前应用程序在后台停留的时长、当前应用程序最近一次被切换至后台的时间、耳机插孔的插拔状态、充电状态、电池电量信息以及屏幕显示时长等等;还可包括终端中集成的传感器采集到的数据,如运动传感器、光线传感器、温度传感器以及湿度传感器等等。
示例性的,可根据所选用的机器学习模型选择合适的样本元素,也可根据所选的样本元素确定所选用的机器学习模型,还可结合对预测准确度以及预设速度等方面的需求进行模型及样本元素的选择等,本申请实施例不做限定。
本申请实施例中,确定待预加载应用程序可以包括根据预测模型之前的输出结果确定待预加载应用程序,也可以包括利用预测模型进行预测,将预测模型的当前输出结果确定待预加载应用程序。
本申请实施例中,当待预加载应用程序为多个(N个)时,预测模型可以输出候选应用程序集合中每个候选应用集合的启动概率,将启动概率较高的候选应用确定为待预加载应用程序。可选的,所述确定待预加载应用程序,包括:预测候选应用程序的启动概率;将启动概率较高的预设数值个候选应用程序确定为待预加载应用程序。示例性的,候选应用程序可包括终端中安装的所有应用程序,也可包括部分应用程序。部分应用程序可以不包含系统应用程序,还可以不包含用户很少使用的应用程序。本申请实施例对候选应用程序的确定方式以及数量不做限定。可选的,可根据当前时刻之前的预设时段内各应用程序的使用次数和/或使用时长确定候选应用程序,预设时段例如是1个月,当使用次数和/或使用时长超过相应的阈值时,将所对应的应用程序确定为候选应用程序,或者,按照使用次数和/或使用时长对各应用程序进行排序,将排名靠前的应用程序确定为候选应用程序。
示例性的,可采用上文所述的预测模型来确定各候选应用程序的启动概率。例如,按照预测模型训练时的训练样本,采集当前样本,将当前样本输入至预测模型中,得到各候选应用程序的启动概率。可对启动概率进行由高到低的排序,将排在前N(N为预设数值)的候选应用程序确定为待加载应用程序。这样设置的好处在于,能够对多个应用程序进行预加载,且这多个应用程序是根据启动概率来确定的,可以提高预测的准确性。
步骤102、开始对所述待预加载应用程序进行预加载操作。
本申请实施例中,当待预加载应用程序仅有一个时,无需考虑应用的预加载顺序;而当待预加载应用程序有多个时,可将多个待预加载应用程序逐一确定为当前待预加载应用程序,并依次进行预加载操作,也可将2个以上待预加载的应用程序确定为当前待预加载应用程序,并同时进行预加载操作,也就是说多个应用程序的预加载过程可以是并行进行的。
本申请实施例中对预加载的具体过程以及所加载的资源不做限定,例如可为待预加载应用程序分配相应的硬件资源,并基于分配的硬件资源加载启动所需的相关数据。示例性的,可包括应用进程启动、应用服务启动、内存分配、文件内容读取、网络数据获取以及界面渲染(如绘制应用程序的启动画面)等。此外,预加载的资源也可根据待预加载应用程序的具体类型来确定。
步骤103、在对所述待预加载应用程序进行预加载操作的过程中,实时监测前台应用程序的运行状态。
在对待预加载应用程序进行预加载的过程中,需要占用一定的系统资源,例如新建进程、启动服务、占用内存、占用中央处理器(Central Processing Unit,CPU)的运算资源、影响网络数据获取速率、以及占用界面绘制所需资源等等。而前台应用程序在运行的过程中,对系统资源的需求是会根据运行状态的变化而有所区别的,有时需求量较大,有时需求量较小。为了保证前台应用程序的正常运行或运行的流畅性,避免造成系统卡顿以影响用户的使用体验,本申请实施例中对前台应用程序的运行状态进行实时监测,以便根据监测结果对应用程序的预加载过程进行控制和调整。
本申请实施例中,前台应用程序的运行状态可包括前台应用程序打开的代码路径、所调用的函数、启动的进程数量、对CPU的使用情况、网络数据获取情况、以及用户对前台应用程序施加的各种操作(或者说前台应用程序在用户的操作下执行的相关步骤或流程等)等。
步骤104、当检测到所述运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作。
本申请中,对第一预设条件的具体内容不做限定。示例性的,可通过实验、仿真或理论计算等方式确定前台应用程序处于哪些运行状态的情况下,如果继续对应用程序进行预加载操作,会对前台应用程序造成不利的影响,或者说对系统的运行产生不良的作用,进而确定第一预设条件。
当检测到所述运行状态满足第一预设条件时,说明此时并不适合继续进行预加载操作,可暂停当前待预加载应用程序的预加载操作,也可终止当前待预加载应用程序的预加载操作。
当暂停当前待预加载应用程序的预加载操作时,可记录预加载进度信息,预加载进度信息可包括已完成预加载的资源的内容或步骤,还可包括预加载进度标记等,方便后续恢复预加载。暂停的好处在于,可保留已经完成预加载的部分资源,待恢复预加载时,可在保留的部分资源基础上继续加载,提高预加载效率,避免系统资源的浪费。
当终止当前待预加载应用程序的预加载操作时,可对当前待预加载应用程序对应的已预加载资源进行释放或清除,在具备预加载条件时,重新开始当前待预加载应用程序的预加载操作。终止的好处在于,可保证预加载操作的连续性,避免恢复预加载时出现错误。
本申请实施例中提供的应用程序预加载方法,检测到应用预加载事件被触发时,确定待预加载应用程序,开始对待预加载应用程序进行预加载操作,在对待预加载应用程序进行预加载操作的过程中,实时监测前台应用程序的运行状态,当检测到运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作。通过采用上述技术方案,可以在应用程序预加载的过程中兼顾前台应用程序的运行情况,必要时暂停或终止预加载操作,避免对前台应用程序造成过多影响。
在一些实施例中,所述当检测到所述运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作,可包括:当检测到所述前台应用程序对应的中央处理器CPU使用率大于第一预设使用率阈值时,暂停或终止当前待预加载应用程序的预加载操作。这样设置的好处在于,前台应用程序是用户当前正在使用的应用程序,一般优先保证前台应用程序的运行性能,当前台应用程序对应的CPU使用率较高时,说明当前情况下,前台应用程序可能在进行一些复杂的操作,需要较多的资源,可暂停或终止预加载操作,以保证前台应用程序的运行性能。另外,后台应用程序也是需要占用CPU资源的,而某些后台应用程序可能比较重要,不能被清理,当前台应用程序对应的CPU使用率较高的情况下,还可能发生预加载操作抢占后台应用程序CPU资源的情况,导致不应该被清理的后台应用程序被误清理,影响系统的整体运行性能。其中,第一预设使用率阈值可根据实际情况进行设置,例如可以是60%。
在一些实施例中,所述当检测到所述运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作,可包括:当检测到所述前台应用程序对应的网络数据获取速率小于预设速率阈值时,暂停或终止当前待预加载应用程序的预加载操作。对待预加载应用程序进行预加载的过程中,可能会涉及到网络数据获取的情况,而当检测到前台应用程序对应的网络数据获取速率小于预设速率阈值时,可能是预加载操作占用了较多的带宽,导致前台应用程序的网络数据获取的速率较小,因此,本申请实施例可暂停或终止预加载操作,保证前台应用程序的数据获取速度。预设速率阈值可根据实际的网络性能情况确定,例如可以是最大速率的预设比例值(如50%)。
在一些实施例中,所述当检测到所述运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作,可包括:当检测到所述前台应用程序正在进行预设代码路径的打开操作时,暂停或终止当前待预加载应用程序的预加载操作。预设代码路径可包括前台应用程序运行过程中涉及到的关键性代码,在检测到前台应用程序正在进行预设代码路径的打开操作时,可认为前台应用程序正在执行比较重要的操作或任务,为保证重要操作或重要任务的顺利进行或完成,本申请实施例可暂停或终止预加载操作。
在一些实施例中,所述预设代码路径包括:所述前台应用程序开始打开预设应用界面到所述预设应用界面打开结束期间涉及到的代码路径。这样设置的好处在于,通常在打开一个新的应用界面时,相比于在同一界面上的持续运行,应用程序一般需要调用或占用更多的系统资源来进行界面绘制或更新等操作,因此,为了保证应用界面的成功或快速打开,可以暂停或终止预加载操作。示例性的,预设应用界面可包括应用程序中的所有应用界面;预设应用界面也可包括预设类型或预先设定好的应用界面,不同的前台应用程序可以对应不同的设置,例如,对于某个应用程序来说,有一些应用界面在打开时耗费时间比较长,或需要占用的系统资源比较多,可以将这些应用界面设定为预设应用界面。具体的,预设代码路径可以包括应用程序打开前至应用程序被完全打开的过程中,需要访问的代码路径(此时预设应用界面可包括启动动画和/或启动界面);。示例性的,检测到用户触发打开应用界面A的时刻为t1,也即检测到预设代码路径被触发打开的时刻为t1,预设代码路径被完全加载完的时刻为t2,则在t1-t2这段时间内,暂停对当前待预加载应用程序的预加载操作。
在一些实施例中,其特征在于,所述检测到所述前台应用程序正在进行预设代码路径的打开操作,包括:在检测到预设打开代码时,确定所述前台应用程序开始打开预设应用界面;在检测到预设结束代码时,确定所述前台应用程序的预设应用界面打开结束。这样设置的好处在于,可在系统内应用界面被打开前和应用界面打开完成这两个位置处添加预先设定的代码,通过对预设代码的检测,即可快速准确地确定前台应用程序是否正在进行预设代码路径的打开操作。
在一些实施例中,在暂停或终止当前待预加载应用程序的预加载操作之后,还包括:当检测到所述前台应用程序的运行状态满足第二预设条件时,继续或重启当前待预加载应用程序的预加载操作。示例性的,第二预设条件可以与第一预设条件对应设置,也即当预加载操作不会对前台应用程序的运行产生不良影响时,可以恢复预加载操作。示例性的,与前文中列举的几种情况相对应,可以有如下实现方式:当检测到前台应用程序对应的CPU使用率小于第二预设使用率阈值(如30%)时、当检测到前台应用程序对应的网络数据获取速率大于第二预设速率阈值时或者当检测到前台应用程序完成预设代码路径的打开操作时,可认为检测到前台应用程序的运行状态满足第二预设条件。
示例性的,当暂停当前待预加载应用程序的预加载操作时,在暂停或终止当前待预加载应用程序的预加载操作之后,继续当前待预加载应用程序的预加载操作;当终止当前待预加载应用程序的预加载操作时,在暂停或终止当前待预加载应用程序的预加载操作之后,重启(也即重新开始)当前待预加载应用程序的预加载操作。
在一些实施例中,所述开始对所述待预加载应用程序进行预加载操作,包括:对于当前待预加载应用程序,在满足预设预加载条件时,开始对所述当前待预加载应用程序进行预加载操作。这样设置的好处在于,在开始对每个待预加载应用程序进行预加载操作之前,判断是否满足一定的预加载条件,避免预加载操作对系统造成过多,减少不必要的预加载操作。所述预设预加载条件可根据实际情况进行设置。例如,所述预设预加载条件包括以下至少一项:当前时刻到达预设预加载时间;预加载开关处于开启状态;当前待预加载应用程序处于白名单中;已预加载的应用程序少于预设数量阈值;当前待预加载应用程序未运行;终端可用内存值大于预设内存阈值;以及终端的CPU使用率小于第二预设使用率阈值。本申请实施例中,通过设置上述条件,可以有效避免预加载过程中造成卡顿等问题。示例性的,预设预加载时间可以是按照预设的时间间隔进行待预加载应用程序的预加载,例如,在确定待预加载应用程序之后,将待预加载应用程序按照启动概率由大至小的顺序加入预加载列表(记为Candidate),优先对启动概率大的应用程序进行预加载,每隔预设时间间隔(如10秒)从预加载列表中选择下一个应用程序进行预加载,并且将被选择的应用程序从Candidate中删除,直到Candidate为空。可设置预加载开关,由系统或用户来控制开关状态,开关处于开启状态时,进行预加载,若开关处于关闭状态,可不进行预加载或终止预加载。还可设置白名单,将可以进行预加载的应用程序加入该白名单中,而一些没有必要进行预加载或预加载时会产生过多不良影响的应用程序被排除在白名单之外。为避免预加载应用程序占用过多的系统资源,还可对应用数量进行限制,如4个。当应用程序已经运行时,可不对当前从Candidate中选择的应用程序进行预加载,因为该应用程序不会再次启动。另外,当系统可用内存小于预设内存阈值(如1G)时,由于预加载应用程序时也会占用系统内存,系统内存不足时,会影响前台应用程序的运行效率,因此,可不对当前待预加载应用程序进行预加载。当终端系统的CPU使用率大于或等于第二预设使用率(如50%)时,为了保证前台应用程序运行的流畅性,可不对当前待预加载应用程序进行预加载。可选的,预设预加载条件包含上述项目中的多个项目,多个项目可以是所有项目,这样能够更好的保证系统的运行性能。
在一些实施例中,所述检测到应用预加载事件被触发时,确定待预加载应用程序,包括:检测到前台应用程序的切换操作时,确定应用预加载预测事件被触发;获取当前前台应用程序对应的前序使用序列;将所述前序使用序列输入至基于机器学习的预设预测模型中;根据所述预设预测模型的输出结果预测出即将启动的待预加载应用程序。其中,采用的机器学习算法可以是RNN算法。前序使用序列可以理解为,从当前时刻往前追溯预设时间段内,与当前运行的前台应用程序相关的应用程序使用时序关联序列。示例性的,当检测应用程序B切换到应用程序A时,表明检测到前台运行应用程序的切换操作,此时,当前运行的第一应用程序为应用程序A,上一时刻运行的应用程序为应用程序B,则当前运行的第一应用程序A的前序使用序列为:应用程序B-应用程序A。又示例性的,当前运行的第一应用程序为应用程序C,上一时刻运行的应用程序为应用程序D,在上一时刻的前一时刻运行的应用程序为应用程序E。可以理解的是,先由应用程序E切换到应用程序D,再由应用程序D切换到应用程序C,则当前运行的应用程序C的前序使用序列可以表示为:应用程序E-应用程序D-应用程序C。需要说明的是,本申请实施例对第一应用程序的第一前序使用序列中包含的应用程序的数量不做限定。这样设置的好处在于,每当前台应用程序发生变更时,当前前台应用程序对应的前序使用序列就会发生变化,而基于应用程序被打开的顺序,可以快速准确地预测出用户即将使用的应用程序。可选的,可在预设历史周期内记录终端中各应用程序被打开的顺序,即前台应用程序发生切换时,记录切换后的应用程序,得到应用程序序列。采用RNN网络进行训练,采用的步长为2,因此在样本抽取时,每2个应用程序即可形成一个训练样本,紧随其后的应用程序为该训练样本的样本标记。例如,存储的应用序列为1,2,2,5,3…,其中的数字代表应用程序的数字编号,则可拆解成样本(1,2→2),(2,2→5),(2,5→3),…,其中每个样本中前两个数为输入,→符号后的数为对应的样本标记。将训练样本依次输入至预设的RNN网络中,得到最终的应用预测模型。
在一些实施例中,所述对所述待预加载应用程序进行预加载操作,包括:基于预先创建的预加载活动窗口堆栈预加载所述待预加载应用程序对应的应用界面,其中,所述预加载活动窗口堆栈对应的边界坐标位于显示屏幕的坐标范围之外。这样设置的好处在于,对应用界面进行预加载,能够较大程度地完成应用启动前的准备工作,提升待预加载应用程序的启动速度,且不会影响到前台应用程序的显示内容在显示屏幕上的显示。
本申请实施例中,活动窗口可理解为一个独立的直接面向用户提供交互和操作的界面,在不同的操作系统中可能采用不同的名词来命名该界面。为了便于理解,下面以安卓(Android)操作系统为例进行下面的说明。
在Android系统中,活动窗口被称为Activity。Activity是一个负责与用户交互的组件,其提供一个屏幕(可以理解为屏幕界面,而非实体的显示屏幕),以供用户交互完成某项任务。在一个android应用程序中,一个Activity通常就是一个单独的屏幕,它上面可以显示一些控件也可以监听并处理用户的事件。在对Activity进行管理中,有这样两个概念:Task(任务栈)和Stack(活动窗口堆栈)。Task对应一个应用程序,Task用于存放Activity,一个Task中可以存放一个或多个Activity,且这些Activity遵循“先进后出,后进先出”的原则。而Stack又用于对Task进行管理,通常,一个Stack对一个屏幕所需展示的各Activity所属的Task进行管理,一个Stack可以管理一个或多个Task,当然,Stack也同样遵循堆栈的基本管理原则。这里所述的屏幕并不一定是完整独立的显示屏,以“两个屏幕”为例,这两个屏幕可能只是一个完整显示屏中两个独立显示各自显示内容的区域。当然,如果终端具备两个甚至是两个以上的独立显示屏,则“两个屏幕”也可以是两个独立的显示屏。
在Android系统中,支持多窗口模式,可包括分屏模式、画中画模式以及自由模式(FreeForm)。在多窗口模式下,应用程序所在的Stack可以有自己的尺寸(size),可以包括以终端屏幕左上角为原点的坐标系中的上下左右坐标。例如,(a,b,c,d),一般描述的是一个矩形的边界,可采用矩形左上角的坐标和右下角的坐标进行表示,即矩形的左上角坐标为(a,b),右下角坐标为(c,d),这样的矩形区域就对应Stack的size。Stack中的应用内布局是以Stack的size为准的,也就是说Activity对应的应用界面是在size的边界范围内进行显示的。
在多窗口模式下,可以允许多个应用程序处于可见状态,包括系统和用户均可见和仅系统可见。系统和用户均可见指的是在显示屏幕上进行显示,且用户能够看到;仅系统可见指的是操作系统可见,而用户不可见,可能被前台的应用遮挡或者如本申请所要实现的在显示屏幕外显示。
本申请实施例中,在显示屏幕外对待预加载应用程序的应用界面进行预加载,可以基于操作系统的多窗口机制来实现,通过多窗口机制将应用程序对应的size设在显示屏幕外而达到对用户不可见的目的,从而不会影响到前台应用程序的显示内容在显示屏幕上的显示。
一般的,多窗口模式下,可以存在多种类型的Stack,如Home Stack表示桌面应用显示的Stack,App Stack表示第三方应用显示,还可以有其他分屏Stack等。本申请实施例中,新增了预加载活动窗口堆栈(预加载Stack),用于表示预加载应用显示的Stack,并设置预加载Stack的边界坐标位于显示屏幕的坐标范围之外,待预加载的应用程序可以显示在该Stack。对于Android系统来说,可以基于Android系统的多窗口机制,新建一个专门用于显示预加载应用的Stack。本申请实施例中,新建Stack是因为可以让新建的预加载Stack拥有自己的size以及可见性,从而实现在显示屏幕外预加载的目的。
本申请实施例中,对预加载Stack的创建时机不做限定,可以是在终端出厂前默认设置预加载Stack处于常驻状态,即预加载Stack一直存在;也可以在终端开机时或终端解锁成功后创建;还可以在应用预加载事件被触发后(可以在确定待预加载应用程序之前)创建等等。可选的,所述基于预先创建的预加载活动窗口堆栈预加载所述待预加载应用程序对应的应用界面,包括:判断是否存在预先创建的预加载活动窗口堆栈;若不存在,则按照预设规则创建预加载活动窗口堆栈;基于所创建的预加载活动窗口堆栈预加载所述待预加载应用程序对应的应用界面。这样设置的好处在于,在确定待预加载的待预加载应用程序之后,判断预加载Stack是否存在,若存在,则无需新建,若不存在,则进行创建,可以节省系统资源。可以理解的是,当待预加载应用程序包含多个时,也即需要在短时间内连续预加载多个应用程序时,在第一个待预加载应用程序开始加载前,预加载Stack已创建完毕,那么第二个待预加载应用程序开始加载前,预加载Stack是存在的,可以不必进行上述判断。
本申请实施例中,对基于预加载Stack预加载待预加载应用程序对应的应用界面的具体过程不做限定,例如可以基于预加载Stack的size进行应用界面的绘制并显示等。
在一些实施例中,所述基于预先创建的预加载活动窗口堆栈预加载所述待预加载应用程序对应的应用界面,包括:创建所述待预加载应用程序对应的目标进程;在预先创建的预加载活动窗口堆栈中创建所述待预加载应用程序对应的任务栈;基于所述目标进程在所述任务栈中启动所述待预加载应用程序对应的活动窗口;基于所启动的活动窗口绘制并显示所述待预加载应用程序对应的应用界面。这样设置的好处在于,能够基于屏幕坐标范围之外的预加载活动窗口堆栈对待预加载应用程序的应用界面进行绘制并显示,不会干扰前台应用程序的运行及显示,保证系统稳定性,同时有效提高待预加载应用程序启动时的速度。在创建目标进程的同时,还可包括目标进程的初始化过程。在上述步骤的执行过程中,还可能涉及其他资源的预加载,如应用服务启动、内存分配、文件内容读取及网络数据获取等,本申请实施例对其他资源的预加载过程不做限定。
在一些实施例中,还包括:向所述待预加载应用程序发送伪造焦点通知,并基于所述伪造焦点通知在预设时间段内保持所述待预加载应用程序对应的应用界面的持续绘制以及显示更新。这样设置的好处在于,能够在待预加载应用程序获得焦点并对系统可见的情况下完成应用界面的绘制及显示,提高预加载的完成度,且不对前台应用的焦点产生影响。本申请实施例中的焦点又称为输入焦点,伪造焦点与前台应用对应的焦点相互独立。一般的,对于目前的Android系统来说,焦点是唯一的,例如触摸等输入操作只对焦点生效,对于输入焦点信息,系统端和应用端是一致的,系统端一旦修改输入焦点信息,就会向应用发送输入焦点信息发生变化的信息,以此方法保证系统端和应用端输入焦点信息一致。本申请实施例中,通过分离系统端和应用端输入焦点信息的方式,实现应用端可伪造焦点的目的。具体的,本申请实施例中,对预加载应用伪造焦点通知,使预加载应用具有焦点信息,而系统端的焦点信息仍然是正确的,这样处理可以使得预加载应用能够正常绘制,达到全部加载的目的。焦点存在于系统端和应用端,可认为是服务端(server)和客户端(client),系统端记录拥有焦点的应用,应用端保存标志位(flag)标识自己是否有焦点。伪造输入焦点的时机可以是当Android的窗口系统新增窗口,需要更新焦点时,生成伪造焦点通知并进行发送。伪造焦点的方法可以是调用窗口的client端的改变窗口焦点的方法,使得该窗口获取焦点。具体的,可基于Binder机制进行伪造焦点通知的发送,Binder机制是Android系统的进程间通信的最常用的方式,采用c/s架构,即客户/服务架构。
本申请实施例中,预设时间段可根据实际情况设计,例如可以是开始预加载后的固定时长范围内,也可以是开始预加载到完成预加载的时段等。在一些实施例中,所述预设时间段的长度包括所述待预加载应用程序中启动广告或启动动画的播放时长。一些应用程序在启动的过程中,通常会播放一些广告或动画,广告或动画的播放时长通常为3秒至十几秒不等,在播放广告或动画期间,用户可能没办法进行任何操作,只能等待播放完毕,浪费用户的宝贵时间。本申请实施例这样设置的好处在于,能够在待预加载应用程序启动之前,在屏幕外播放完启动广告或启动动画,当待预加载应用程序启动时,可直接进入应用程序的主页面或其他用户可操作的界面,从而将待预加载应用程序的可操作时间点进一步提前,减少等待时间。
对于一些终端来说,尤其是手机及平板电脑等移动终端,为了方便用户的使用,显示屏幕的显示方式通常包括竖屏显示和横屏显示,许多应用程序默认采用竖屏方式进行显示,而有些应用程序默认采用横屏方式进行显示(如一些网络游戏),在终端的使用过程中,有些应用程序还会随着用户握持终端的方向而进行横竖屏显示的切换。在本申请的一些实施例中,所述预加载活动窗口堆栈对应的边界坐标为(H,0,2H,H),所述边界坐标对应的坐标系为系统坐标,所述系统坐标的原点为所述显示屏幕的左上角,H为所述显示屏幕的显示区域的长边长度。也就是说,H对应的边是显示屏幕的显示区域的最大边,在竖屏显示时为显示屏幕的高,在横屏显示时为显示屏幕的宽。这样设置的目的是考虑到显示屏幕横屏、预加载应用横屏显示,以及一些应用程序的正常显示。图2为本申请实施例提供的一种预加载活动窗口堆栈与显示屏幕显示区域的相对位置关系示意图。如图2所示,此时显示屏幕为竖屏方式,终端系统坐标的原点为显示屏幕201的左顶点(0,0),显示屏幕201的宽度方向为X轴,高度方向为Y轴,预加载Stack202对应的边界坐标为(H,0,2H,H),H为屏幕高,即左边实线矩形范围内的区域为主屏幕显示区域,右边虚线矩形范围内的区域为预加载显示区域。图3为本申请实施例提供的又一种预加载活动窗口堆栈与显示屏幕显示区域的相对位置关系示意图。如图3所示,此时显示屏幕为横屏方式,终端系统坐标的原点为显示屏幕301的左顶点(0,0),显示屏幕301的高度方向为X轴,宽度方向为Y轴,预加载Stack202对应的边界坐标为(H,0,2H,H),H为屏幕高,即左边实线矩形范围内的区域为主屏幕显示区域,右边虚线矩形范围内的区域为预加载显示区域。
预加载Stack各个边界如此设置的原因在于:
左上角的横坐标为H,是为了防止横屏时显示屏幕(也可称为主屏幕)显示到预加载应用的界面,因为主屏幕除了竖屏模式,还有横屏模式,当主屏幕横屏的时候,为了防止主屏幕显示区域显示了预加载的应用的局部,所以将预加载Stack对应的矩形区域的左上角横坐标设为屏幕高。
左上角的纵坐标为0,是为了预加载应用能够正确计算状态栏高度。Android应用为了更好的设计用户界面(User Interface,UI),会自定义顶部状态栏,如果上边对应的纵坐标不等于0,那么状态栏的高度可能会错误。
右下角的横坐标为2H(2倍屏幕高),即预加载Stack对应的矩形的宽=屏幕高,是为了预加载Stack的size能够包含预加载时候的横屏应用(即应用界面为横屏显示方式的应用程序)。
右下角的纵坐标为H,即预加载Stack对应的矩形的高=屏幕高,是为了预加载Stack的size能够包含预加载时候的竖屏应用。
基于上述的原因,发明人将预加载Stack的size设置为(H,0,2H,H)。
在一些实施例中,在接收到已进行预加载的预加载应用程序(当待预加载应用程序已进行了预加载操作后,可将该待预加载应用程序称为预加载应用程序)的运行指令时,将所述预加载活动窗口堆栈中包含的所述预加载应用程序对应的应用界面迁移至所述显示屏幕进行显示。具体的,所述将所述预加载活动窗口堆栈中包含的所述预加载应用程序对应的应用界面迁移至所述显示屏幕进行显示,包括:将所述预加载活动窗口堆栈中包含的所述预加载应用程序对应的任务栈迁移至应用活动窗口堆栈的顶部;更新所述任务栈的尺寸信息、配置信息和可见性,以实现所述预加载应用程序对应的应用界面在所述显示屏幕进行显示。这样设置的好处在于,能够保证界面迁移过程的稳定性,保证恢复过程不会出现卡屏、黑屏或迁移速度慢等问题。
此外,图4为本申请实施例提供的一种应用界面迁移示意图,如图4所示,在接收到目标应用程序的运行指令时,将预加载活动窗口堆栈中包含的目标应用程序对应的应用界面401迁移至显示屏幕201进行显示,具体的,将预加载应用界面所属的task迁移至应用活动窗口Stack的顶部,并更新该task的尺寸信息、配置信息和可见性,从而应用界面能够在显示屏幕上正常显示。
图5为本申请实施例提供的另一种应用程序预加载方法的流程示意图,该方法包括如下步骤:
步骤501、检测到应用预加载事件被触发时,确定待预加载应用程序。
步骤502、开始对待预加载应用程序进行预加载操作。
步骤503、在对当前待预加载应用程序进行预加载操作的过程中,实时监测前台应用程序的运行状态。
步骤504、在检测到预设打开代码时,确定前台应用程序开始打开预设应用界面。
步骤505、暂停当前待预加载应用程序的预加载操作,并记录预加载进度。
步骤506、在检测到预设结束代码时,确定前台应用程序的预设应用界面打开结束。
步骤507、在所记录的预加载进度基础上,继续对当前待预加载应用程序进行预加载操作。
步骤508、在接收到已进行预加载的目标应用程序的运行指令时,基于预加载资源启动目标应用程序。
本申请实施例提供的应用程序预加载方法,在对待预加载应用程序进行预加载操作的过程中,判断前台应用程序是否打开预设应用界面,若是,则暂停预加载,待预设应用界面完全打开后,再恢复预加载操作,在不影响前台应用程序打开预设界面的基础上,快速完成待预加载应用程序的预加载操作,待接收到用户针对已进行预加载的目标应用程序的打开指示时,基于已预加载的资源快速打开目标应用程序,提高目标应用程序的启动速度。
图6为本申请实施例提供的又一种应用程序预加载方法的流程示意图,该方法包括:
步骤601、检测到前台应用程序的切换操作时,获取当前前台应用程序对应的前序使用序列。
步骤602、将前序使用序列输入至基于RNN的预设预测模型中,根据预设预测模型的输出结果预测出即将启动的待预加载应用程序,并形成待加载列表。
示例性的,预设预测模型会输出候选应用程序的启动概率值,假设待预加载应用程序数量为4个,则可将启动概率值排名前4的应用程序加入待加载列表中,待加载列表中的第一个应用程序对应的启动概率值最高。
步骤603、对于待加载列表中的当前待预加载应用程序,判断是否满足预设预加载条件,若是,则执行步骤604;否则,重复执行步骤603。
其中,预设预加载条件为同时满足以下项目:当前时刻到达预设预加载时间;预加载开关处于开启状态;当前待预加载应用程序处于白名单中;已预加载的应用程序少于预设数量阈值;当前待预加载应用程序未运行;终端可用内存值大于预设内存阈值;终端的CPU使用率小于第二预设使用率阈值。
可以理解的是,首次执行本步骤时,当前待预加载应用程序为待加载列表中的第一个应用程序。在重复执行步骤603时,可根据不满足预设预加载条件中的具体项目来确定继续针对当前待预加载应用程序进行判定,还是将下一个待预加载应用程序作为新的当前待预加载应用程序进行判定。
步骤604、基于预加载活动窗口堆栈对当前待预加载应用程序的应用界面进行预加载,并实时监测前台应用程序的运行状态。
其中,所述预加载活动窗口堆栈对应的边界坐标位于显示屏幕的坐标范围之外。
步骤605、判断前台应用程序是否开始进行预设代码路径的打开操作,若是,则执行步骤606;否则,重复执行步骤605。
示例性的,对预设代码路径的打开操作是否开始进行的判定可以是实时的,或采用预设判定频率进行的,若判定为否,则进行下一次判定,同时对当前待预加载应用程序的预加载操作继续进行,不受影响。
步骤606、终止当前待预加载应用程序的预加载操作。
步骤607、判断预设代码路径的打开操作是否完成,若是,则执行步骤608;否则,重复执行步骤607。
步骤608、重新基于预加载活动窗口堆栈对当前待预加载应用程序的应用界面进行预加载。
步骤609、在接收到已进行预加载的目标应用程序的运行指令时,将预加载活动窗口堆栈中包含的目标应用程序对应的应用界面迁移至显示屏幕进行显示。
本申请实施例提供的应用程序预加载方法,利用应用序列对待启动的应用程序进行预测,在对当前待预加载应用程序进行预加载操作之前,先判断是否满足预加载条件,若满足,则在预加载过程中,判断前台应用程序是否进行预设代码的打开操作,若是,则停止预加载,待预设应用界面完全打开后,再重新对该应用程序进行预加载操作,在不影响前台应用程序打开预设界面的基础上,避免预加载发生错误,提高预加载成功率,待接收到用户针对已进行预加载的目标应用程序的打开指示时,将已预加载好的应用界面迁移至显示屏幕进行显示,从而快速打开目标应用程序,提高目标应用程序的启动速度。
图7为本申请实施例提供的一种应用程序预加载装置的结构框图,该装置可由软件和/或硬件实现,一般集成在终端中,可通过执行应用程序预加载方法来进行应用程序的预加载。如图7所示,该装置包括:
应用确定模块701,用于在检测到应用预加载事件被触发时,确定待预加载应用程序;
预加载模块702,用于开始对所述待预加载应用程序进行预加载操作;
运行状态监测模块703,用于在对所述待预加载应用程序进行预加载操作的过程中,实时监测前台应用程序的运行状态;
预加载调整模块704,用于在检测到所述运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作。
本申请实施例中提供的应用程序预加载装置,检测到应用预加载事件被触发时,确定待预加载应用程序,开始对待预加载应用程序进行预加载操作,在对待预加载应用程序进行预加载操作的过程中,实时监测前台应用程序的运行状态,当检测到运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作。通过采用上述技术方案,可以在应用程序预加载的过程中兼顾前台应用程序的运行情况,必要时暂停或终止预加载操作,避免对前台应用程序造成过多影响。
可选的,所述当检测到所述运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作,包括:
当检测到所述前台应用程序正在进行预设代码路径的打开操作时,暂停或终止当前待预加载应用程序的预加载操作;或者,
当检测到所述前台应用程序对应的中央处理器CPU使用率大于第一预设使用率阈值时,暂停或终止当前待预加载应用程序的预加载操作;或者,
当检测到所述前台应用程序对应的网络数据获取速率小于预设速率阈值时,暂停或终止当前待预加载应用程序的预加载操作。
可选的,所述预设代码路径包括:所述前台应用程序开始打开预设应用界面到所述预设应用界面打开结束期间涉及到的代码路径。
可选的,所述检测到所述前台应用程序正在进行预设代码路径的打开操作,包括:
在检测到预设打开代码时,确定所述前台应用程序开始打开预设应用界面;
在检测到预设结束代码时,确定所述前台应用程序的预设应用界面打开结束。
可选的,所述开始对所述待预加载应用程序进行预加载操作,包括:
对于当前待预加载应用程序,在满足预设预加载条件时,开始对所述当前待预加载应用程序进行预加载操作;
其中,所述预设预加载条件包括以下至少一项:
当前时刻到达预设预加载时间;
预加载开关处于开启状态;
当前待预加载应用程序处于白名单中;
已预加载的应用程序少于预设数量阈值;
当前待预加载应用程序未运行;
终端可用内存值大于预设内存阈值;
终端的CPU使用率小于第二预设使用率阈值。
可选的,所述检测到应用预加载事件被触发时,确定待预加载应用程序,包括:
检测到前台应用程序的切换操作时,确定应用预加载预测事件被触发;
获取当前前台应用程序对应的前序使用序列;
将所述前序使用序列输入至基于机器学习的预设预测模型中;
根据所述预设预测模型的输出结果预测出即将启动的待预加载应用程序。
可选的,所述对所述待预加载应用程序进行预加载操作,包括:
基于预先创建的预加载活动窗口堆栈预加载所述待预加载应用程序对应的应用界面,其中,所述预加载活动窗口堆栈对应的边界坐标位于显示屏幕的坐标范围之外。
可选的,预加载模块还用于在暂停或终止当前待预加载应用程序的预加载操作之后,当检测到所述前台应用程序的运行状态满足第二预设条件时,继续或重启当前待预加载应用程序的预加载操作。
本申请实施例还提供一种包含计算机可执行指令的存储介质,所述计算机可执行指令在由计算机处理器执行时用于执行应用程序预加载方法,该方法包括:
检测到应用预加载事件被触发时,确定待预加载应用程序;
开始对所述待预加载应用程序进行预加载操作;
在对所述待预加载应用程序进行预加载操作的过程中,实时监测前台应用程序的运行状态;
当检测到所述运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作。
存储介质——任何的各种类型的存储器设备或存储设备。术语“存储介质”旨在包括:安装介质,例如CD-ROM、软盘或磁带装置;计算机系统存储器或随机存取存储器,诸如DRAM、DDRRAM、SRAM、EDORAM,兰巴斯(Rambus)RAM等;非易失性存储器,诸如闪存、磁介质(例如硬盘或光存储);寄存器或其它相似类型的存储器元件等。存储介质可以还包括其它类型的存储器或其组合。另外,存储介质可以位于程序在其中被执行的第一计算机系统中,或者可以位于不同的第二计算机系统中,第二计算机系统通过网络(诸如因特网)连接到第一计算机系统。第二计算机系统可以提供程序指令给第一计算机用于执行。术语“存储介质”可以包括可以驻留在不同位置中(例如在通过网络连接的不同计算机系统中)的两个或更多存储介质。存储介质可以存储可由一个或多个处理器执行的程序指令(例如具体实现为计算机程序)。
当然,本申请实施例所提供的一种包含计算机可执行指令的存储介质,其计算机可执行指令不限于如上所述的应用程序预加载操作,还可以执行本申请任意实施例所提供的应用程序预加载方法中的相关操作。
本申请实施例提供了一种终端,该终端中可集成本申请实施例提供的应用程序预加载装置。图8为本申请实施例提供的一种终端的结构示意图。终端800可以包括:存储器801,处理器802及存储在存储器801上并可在处理器802运行的计算机程序,所述处理器802执行所述计算机程序时实现如本申请实施例所述的应用程序预加载方法。
本申请实施例提供的终端,可以在应用程序预加载的过程中兼顾前台应用程序的运行情况,必要时暂停或终止预加载操作,避免对前台应用程序造成过多影响。
图9为本申请实施例提供的另一种终端的结构示意图,该终端可以包括:壳体(图中未示出)、存储器901、中央处理器(central processing unit,CPU)902(又称处理器,以下简称CPU)、电路板(图中未示出)和电源电路(图中未示出)。所述电路板安置在所述壳体围成的空间内部;所述CPU902和所述存储器901设置在所述电路板上;所述电源电路,用于为所述终端的各个电路或器件供电;所述存储器901,用于存储可执行程序代码;所述CPU902通过读取所述存储器901中存储的可执行程序代码来运行与所述可执行程序代码对应的计算机程序,以实现以下步骤:
检测到应用预加载事件被触发时,确定待预加载应用程序;
开始对所述待预加载应用程序进行预加载操作;
在对所述待预加载应用程序进行预加载操作的过程中,实时监测前台应用程序的运行状态;
当检测到所述运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作。
所述终端还包括:外设接口903、RF(Radio Frequency,射频)电路905、音频电路906、扬声器911、电源管理芯片908、输入/输出(I/O)子系统909、其他输入/控制设备910、触摸屏912、其他输入/控制设备910以及外部端口904,这些部件通过一个或多个通信总线或信号线907来通信。
应该理解的是,图示终端900仅仅是终端的一个范例,并且终端900可以具有比图中所示出的更多的或者更少的部件,可以组合两个或更多的部件,或者可以具有不同的部件配置。图中所示出的各种部件可以在包括一个或多个信号处理和/或专用集成电路在内的硬件、软件、或硬件和软件的组合中实现。
下面就本实施例提供的用于应用预加载的终端进行详细的描述,该终端以手机为例。
存储器901,所述存储器901可以被CPU902、外设接口903等访问,所述存储器901可以包括高速随机存取存储器,还可以包括非易失性存储器,例如一个或多个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
外设接口903,所述外设接口903可以将设备的输入和输出外设连接到CPU902和存储器901。
I/O子系统909,所述I/O子系统909可以将设备上的输入输出外设,例如触摸屏912和其他输入/控制设备910,连接到外设接口903。I/O子系统909可以包括显示控制器9091和用于控制其他输入/控制设备910的一个或多个输入控制器9092。其中,一个或多个输入控制器9092从其他输入/控制设备910接收电信号或者向其他输入/控制设备910发送电信号,其他输入/控制设备910可以包括物理按钮(按压按钮、摇臂按钮等)、拨号盘、滑动开关、操纵杆、点击滚轮。值得说明的是,输入控制器9092可以与以下任一个连接:键盘、红外端口、USB接口以及诸如鼠标的指示设备。
触摸屏912,所述触摸屏912是用户终端与用户之间的输入接口和输出接口,将可视输出显示给用户,可视输出可以包括图形、文本、图标、视频等。
I/O子系统909中的显示控制器9091从触摸屏912接收电信号或者向触摸屏912发送电信号。触摸屏912检测触摸屏上的接触,显示控制器9091将检测到的接触转换为与显示在触摸屏912上的用户界面对象的交互,即实现人机交互,显示在触摸屏912上的用户界面对象可以是运行游戏的图标、联网到相应网络的图标等。值得说明的是,设备还可以包括光鼠,光鼠是不显示可视输出的触摸敏感表面,或者是由触摸屏形成的触摸敏感表面的延伸。
RF电路905,主要用于建立手机与无线网络(即网络侧)的通信,实现手机与无线网络的数据接收和发送。例如收发短信息、电子邮件等。具体地,RF电路905接收并发送RF信号,RF信号也称为电磁信号,RF电路905将电信号转换为电磁信号或将电磁信号转换为电信号,并且通过该电磁信号与通信网络以及其他设备进行通信。RF电路905可以包括用于执行这些功能的已知电路,其包括但不限于天线系统、RF收发机、一个或多个放大器、调谐器、一个或多个振荡器、数字信号处理器、CODEC(COder-DECoder,编译码器)芯片组、用户标识模块(Subscriber Identity Module,SIM)等等。
音频电路906,主要用于从外设接口903接收音频数据,将该音频数据转换为电信号,并且将该电信号发送给扬声器911。
扬声器911,用于将手机通过RF电路905从无线网络接收的语音信号,还原为声音并向用户播放该声音。
电源管理芯片908,用于为CPU902、I/O子系统及外设接口所连接的硬件进行供电及电源管理。
上述实施例中提供的应用程序预加载装置、存储介质及终端可执行本申请任意实施例所提供的应用程序预加载方法,具备执行该方法相应的功能模块和有益效果。未在上述实施例中详尽描述的技术细节,可参见本申请任意实施例所提供的应用程序预加载方法。
注意,上述仅为本申请的较佳实施例及所运用技术原理。本领域技术人员会理解,本申请不限于这里所述的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本申请的保护范围。因此,虽然通过以上实施例对本申请进行了较为详细的说明,但是本申请不仅仅限于以上实施例,在不脱离本申请构思的情况下,还可以包括更多其他等效实施例,而本申请的范围由所附的权利要求范围决定。

Claims (11)

1.一种应用程序预加载方法,其特征在于,包括:
检测到应用预加载事件被触发时,确定待预加载应用程序;
开始对所述待预加载应用程序进行预加载操作;
在对所述待预加载应用程序进行预加载操作的过程中,实时监测前台应用程序的运行状态;
当检测到所述运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作。
2.根据权利要求1所述的方法,其特征在于,所述当检测到所述运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作,包括:
当检测到所述前台应用程序正在进行预设代码路径的打开操作时,暂停或终止当前待预加载应用程序的预加载操作;或者,
当检测到所述前台应用程序对应的中央处理器CPU使用率大于第一预设使用率阈值时,暂停或终止当前待预加载应用程序的预加载操作;或者,
当检测到所述前台应用程序对应的网络数据获取速率小于预设速率阈值时,暂停或终止当前待预加载应用程序的预加载操作。
3.根据权利要求2所述的方法,其特征在于,所述预设代码路径包括:所述前台应用程序开始打开预设应用界面到所述预设应用界面打开结束期间涉及到的代码路径。
4.根据权利要求3所述的方法,其特征在于,所述检测到所述前台应用程序正在进行预设代码路径的打开操作,包括:
在检测到预设打开代码时,确定所述前台应用程序开始打开预设应用界面;
在检测到预设结束代码时,确定所述前台应用程序的预设应用界面打开结束。
5.根据权利要求1所述的方法,其特征在于,所述开始对所述待预加载应用程序进行预加载操作,包括:
对于当前待预加载应用程序,在满足预设预加载条件时,开始对所述当前待预加载应用程序进行预加载操作;
其中,所述预设预加载条件包括以下至少一项:
当前时刻到达预设预加载时间;
预加载开关处于开启状态;
当前待预加载应用程序处于白名单中;
已预加载的应用程序少于预设数量阈值;
当前待预加载应用程序未运行;
终端可用内存值大于预设内存阈值;
终端的CPU使用率小于第二预设使用率阈值。
6.根据权利要求1所述的方法,其特征在于,所述检测到应用预加载事件被触发时,确定待预加载应用程序,包括:
检测到前台应用程序的切换操作时,确定应用预加载预测事件被触发;
获取当前前台应用程序对应的前序使用序列;
将所述前序使用序列输入至基于机器学习的预设预测模型中;
根据所述预设预测模型的输出结果预测出即将启动的待预加载应用程序。
7.根据权利要求1所述的方法,其特征在于,所述对所述待预加载应用程序进行预加载操作,包括:
基于预先创建的预加载活动窗口堆栈预加载所述待预加载应用程序对应的应用界面,其中,所述预加载活动窗口堆栈对应的边界坐标位于显示屏幕的坐标范围之外。
8.根据权利要求1-7任一所述的方法,其特征在于,在暂停或终止当前待预加载应用程序的预加载操作之后,还包括:
当检测到所述前台应用程序的运行状态满足第二预设条件时,继续或重启当前待预加载应用程序的预加载操作。
9.一种应用程序预加载装置,其特征在于,包括:
应用确定模块,用于在检测到应用预加载事件被触发时,确定待预加载应用程序;
预加载模块,用于开始对所述待预加载应用程序进行预加载操作;
运行状态监测模块,用于在对所述待预加载应用程序进行预加载操作的过程中,实时监测前台应用程序的运行状态;
预加载调整模块,用于在检测到所述运行状态满足第一预设条件时,暂停或终止当前待预加载应用程序的预加载操作。
10.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1-8中任一所述的应用程序预加载方法。
11.一种终端,其特征在于,包括存储器,处理器及存储在存储器上并可在处理器运行的计算机程序,所述处理器执行所述计算机程序时实现如权利要求1-8任一所述的应用程序预加载方法。
CN201810462478.4A 2018-05-15 2018-05-15 应用程序预加载方法、装置、存储介质及终端 Active CN108762831B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201810462478.4A CN108762831B (zh) 2018-05-15 2018-05-15 应用程序预加载方法、装置、存储介质及终端

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810462478.4A CN108762831B (zh) 2018-05-15 2018-05-15 应用程序预加载方法、装置、存储介质及终端

Publications (2)

Publication Number Publication Date
CN108762831A true CN108762831A (zh) 2018-11-06
CN108762831B CN108762831B (zh) 2021-11-09

Family

ID=64007724

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810462478.4A Active CN108762831B (zh) 2018-05-15 2018-05-15 应用程序预加载方法、装置、存储介质及终端

Country Status (1)

Country Link
CN (1) CN108762831B (zh)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110413347A (zh) * 2019-07-31 2019-11-05 Oppo广东移动通信有限公司 应用程序中广告的处理方法、装置、存储介质及终端
WO2019233354A1 (en) * 2018-06-05 2019-12-12 Guangdong Oppo Mobile Telecommunications Corp., Ltd. Application preloading method and device, storage medium and terminal
CN111666020A (zh) * 2019-03-06 2020-09-15 珠海金山办公软件有限公司 一种文档页面切换的方法、装置、电子设备及存储介质
US20210329090A1 (en) * 2014-07-16 2021-10-21 Tensera Networks Ltd. Scheduling of Application Preloading in User Devices
CN114730267A (zh) * 2019-11-18 2022-07-08 三星电子株式会社 预加载应用的方法和支持该方法的电子装置
US11397590B2 (en) 2018-05-10 2022-07-26 Guangdong Oppo Mobile Telecommunications Corp., Ltd. Method for preloading application, storage medium, and terminal
US11442747B2 (en) 2018-05-10 2022-09-13 Guangdong Oppo Mobile Telecommunications Corp., Ltd. Method for establishing applications-to-be preloaded prediction model based on preorder usage sequence of foreground application, storage medium, and terminal
US11604660B2 (en) 2018-05-15 2023-03-14 Guangdong Oppo Mobile Telecommunications Corp., Ltd. Method for launching application, storage medium, and terminal

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20040030882A1 (en) * 2002-08-08 2004-02-12 Forman George Henry Managed application pre-launching
CN105955766A (zh) * 2016-04-22 2016-09-21 北京小米移动软件有限公司 应用预加载方法及装置
CN106843961A (zh) * 2017-01-19 2017-06-13 上海斐讯数据通信技术有限公司 一种手机应用程序预加载和清理的系统及其使用方法
CN107544822A (zh) * 2017-07-26 2018-01-05 北京珠穆朗玛移动通信有限公司 应用程序预加载方法、移动终端及具有存储功能的装置
CN107783801A (zh) * 2017-11-06 2018-03-09 广东欧珀移动通信有限公司 应用程序预测模型建立、预加载方法、装置、介质及终端
CN108595228A (zh) * 2018-05-10 2018-09-28 Oppo广东移动通信有限公司 应用程序预测模型建立方法、装置、存储介质及移动终端
CN108595227A (zh) * 2018-05-10 2018-09-28 Oppo广东移动通信有限公司 应用程序预加载方法、装置、存储介质及移动终端

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20040030882A1 (en) * 2002-08-08 2004-02-12 Forman George Henry Managed application pre-launching
CN105955766A (zh) * 2016-04-22 2016-09-21 北京小米移动软件有限公司 应用预加载方法及装置
CN106843961A (zh) * 2017-01-19 2017-06-13 上海斐讯数据通信技术有限公司 一种手机应用程序预加载和清理的系统及其使用方法
CN107544822A (zh) * 2017-07-26 2018-01-05 北京珠穆朗玛移动通信有限公司 应用程序预加载方法、移动终端及具有存储功能的装置
CN107783801A (zh) * 2017-11-06 2018-03-09 广东欧珀移动通信有限公司 应用程序预测模型建立、预加载方法、装置、介质及终端
CN108595228A (zh) * 2018-05-10 2018-09-28 Oppo广东移动通信有限公司 应用程序预测模型建立方法、装置、存储介质及移动终端
CN108595227A (zh) * 2018-05-10 2018-09-28 Oppo广东移动通信有限公司 应用程序预加载方法、装置、存储介质及移动终端

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20210329090A1 (en) * 2014-07-16 2021-10-21 Tensera Networks Ltd. Scheduling of Application Preloading in User Devices
US11758014B2 (en) * 2014-07-16 2023-09-12 Tensera Networks Ltd. Scheduling of application preloading in user devices
US11397590B2 (en) 2018-05-10 2022-07-26 Guangdong Oppo Mobile Telecommunications Corp., Ltd. Method for preloading application, storage medium, and terminal
US11442747B2 (en) 2018-05-10 2022-09-13 Guangdong Oppo Mobile Telecommunications Corp., Ltd. Method for establishing applications-to-be preloaded prediction model based on preorder usage sequence of foreground application, storage medium, and terminal
US11604660B2 (en) 2018-05-15 2023-03-14 Guangdong Oppo Mobile Telecommunications Corp., Ltd. Method for launching application, storage medium, and terminal
WO2019233354A1 (en) * 2018-06-05 2019-12-12 Guangdong Oppo Mobile Telecommunications Corp., Ltd. Application preloading method and device, storage medium and terminal
US11467855B2 (en) 2018-06-05 2022-10-11 Guangdong Oppo Mobile Telecommunications Corp., Ltd. Application preloading method and device, storage medium and terminal
CN111666020A (zh) * 2019-03-06 2020-09-15 珠海金山办公软件有限公司 一种文档页面切换的方法、装置、电子设备及存储介质
CN111666020B (zh) * 2019-03-06 2022-05-03 珠海金山办公软件有限公司 一种文档页面切换的方法、装置、电子设备及存储介质
CN110413347A (zh) * 2019-07-31 2019-11-05 Oppo广东移动通信有限公司 应用程序中广告的处理方法、装置、存储介质及终端
CN110413347B (zh) * 2019-07-31 2023-08-18 Oppo广东移动通信有限公司 应用程序中广告的处理方法、装置、存储介质及终端
CN114730267A (zh) * 2019-11-18 2022-07-08 三星电子株式会社 预加载应用的方法和支持该方法的电子装置

Also Published As

Publication number Publication date
CN108762831B (zh) 2021-11-09

Similar Documents

Publication Publication Date Title
CN108804157A (zh) 应用程序预加载方法、装置、存储介质及终端
CN108363593B (zh) 应用程序预加载方法、装置、存储介质及终端
CN108614722A (zh) 应用程序预加载方法、装置、存储介质及终端
CN108762831A (zh) 应用程序预加载方法、装置、存储介质及终端
CN108762843A (zh) 应用程序的预加载方法、装置、存储介质及智能终端
CN108920156A (zh) 应用程序预测模型建立方法、装置、存储介质及终端
CN108958830A (zh) 应用程序启动方法、装置、存储介质及终端
CN108710513A (zh) 应用程序启动方法、装置、存储介质及终端
CN108681475A (zh) 应用程序预加载方法、装置、存储介质及移动终端
CN108647052A (zh) 应用程序预加载方法、装置、存储介质及终端
CN108647055A (zh) 应用程序预加载方法、装置、存储介质及终端
CN108595230A (zh) 应用程序预加载方法、装置、存储介质及终端
CN108595224A (zh) 应用程序提示方法、装置、存储介质及终端
CN108595228A (zh) 应用程序预测模型建立方法、装置、存储介质及移动终端
CN108829456A (zh) 应用程序预加载方法、装置、存储介质及终端
CN108628645A (zh) 应用程序预加载方法、装置、存储介质及终端
CN108829457A (zh) 应用程序预测模型更新方法、装置、存储介质及终端
CN108595231A (zh) 应用程序预加载方法、装置、存储介质及智能终端
CN107783803B (zh) 智能终端的系统优化方法、装置、存储介质及智能终端
CN108762837A (zh) 应用程序预加载方法、装置、存储介质及终端
CN108958828A (zh) 应用程序预加载方法、装置、存储介质及终端
CN108776599B (zh) 预加载应用的管理方法、装置、存储介质及智能终端
CN108804153A (zh) 应用程序的预加载方法、装置、存储介质及终端
CN108647056A (zh) 应用程序预加载方法、装置、存储介质及终端
CN108664285A (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
TA01 Transfer of patent application right
TA01 Transfer of patent application right

Effective date of registration: 20190103

Address after: Room 2101, 600 Longhuazhong Road, Xuhui District, Shanghai, 2002

Applicant after: Shanghai Jinsheng Communication Technology Co., Ltd.

Address before: 523860 No. 18, Wu Sha Beach Road, Changan Town, Dongguan, Guangdong

Applicant before: OPPO Guangdong Mobile Communications Co., Ltd.

GR01 Patent grant
GR01 Patent grant