CN107341094A - 启动项耗时的测量方法及装置 - Google Patents
启动项耗时的测量方法及装置 Download PDFInfo
- Publication number
- CN107341094A CN107341094A CN201610281655.XA CN201610281655A CN107341094A CN 107341094 A CN107341094 A CN 107341094A CN 201610281655 A CN201610281655 A CN 201610281655A CN 107341094 A CN107341094 A CN 107341094A
- Authority
- CN
- China
- Prior art keywords
- starting
- startup
- item
- time
- time consumption
- 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
Links
- 238000000034 method Methods 0.000 title claims abstract description 50
- 238000005457 optimization Methods 0.000 claims description 42
- 238000012544 monitoring process Methods 0.000 claims description 26
- 238000005259 measurement Methods 0.000 claims description 12
- 238000012545 processing Methods 0.000 claims description 8
- 238000001514 detection method Methods 0.000 claims description 7
- 230000000977 initiatory effect Effects 0.000 claims description 3
- 238000005516 engineering process Methods 0.000 abstract description 8
- 230000000694 effects Effects 0.000 abstract description 6
- 230000006870 function Effects 0.000 description 12
- 238000010586 diagram Methods 0.000 description 10
- 238000004891 communication Methods 0.000 description 4
- 230000001133 acceleration Effects 0.000 description 2
- 230000001174 ascending effect Effects 0.000 description 2
- 230000005540 biological transmission Effects 0.000 description 2
- 238000000691 measurement method Methods 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 230000005236 sound signal Effects 0.000 description 2
- 230000001960 triggered effect Effects 0.000 description 2
- 230000009286 beneficial effect Effects 0.000 description 1
- 238000004590 computer program Methods 0.000 description 1
- 230000003247 decreasing effect Effects 0.000 description 1
- 238000007599 discharging Methods 0.000 description 1
- 230000005484 gravity Effects 0.000 description 1
- 230000006698 induction Effects 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 230000007774 longterm Effects 0.000 description 1
- 238000010295 mobile communication Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000010079 rubber tapping Methods 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- GOLXNESZZPUPJE-UHFFFAOYSA-N spiromesifen Chemical compound CC1=CC(C)=CC(C)=C1C(C(O1)=O)=C(OC(=O)CC(C)(C)C)C11CCCC1 GOLXNESZZPUPJE-UHFFFAOYSA-N 0.000 description 1
- 238000010897 surface acoustic wave method Methods 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/34—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
- G06F11/3409—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment
- G06F11/3419—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment by assessing time
- G06F11/3423—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment by assessing time where the assessed time is active or idle time
Landscapes
- Engineering & Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Hardware Design (AREA)
- Quality & Reliability (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Debugging And Monitoring (AREA)
Abstract
本发明公开了一种启动项耗时的测量方法,属于计算机技术领域。所述方法包括:开机完成后,读取性能监控日志中记录的原始数据,所述原始数据为在开机阶段启动各个启动项时记录的数据;根据所述原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序;根据每个启动项的资源占用率和启动顺序调整所述启动项的启动耗时,使得终端可以根据每个启动项的启动顺序以及先前启动的启动项的资源占用率来测量该启动项的启动耗时,解决了相关技术中仅将启动项对应的进程占用CPU的时长确定为启动项在开机阶段的启动耗时,导致的确定的启动耗时不准确的问题,达到了提高确定的启动耗时的准确性的效果。
Description
技术领域
本发明涉及计算机领域,特别涉及一种启动项耗时的测量方法及装置。
背景技术
系统在终端开机时会逐一加载很多启动项,终端需要测量各个启动项在开机阶段的耗时,选择性地禁用耗时超过预设阈值的启动项,以提高终端的开机速度。其中,启动项是指终端在开机后自动运行的加载项,每个启动项对应一个进程,启动项在开机阶段的耗时即启动项对应的进程在开机阶段的耗时。
相关技术提供了一种启动项耗时的测量方法,终端在开机阶段监控各个启动项对应的进程的运行时长,开机完成后获取各个启动项对应的运行时长,将每个启动项对应的运行时长确定为该启动项在开机阶段的耗时。其中,运行时长是启动项对应的进程占用CPU(Central Processing Unit,中央处理器)的时长。
由于运行时长仅是测量启动项在开机阶段耗时的一个参量,因此,将运行时长作为启动项在开机阶段的耗时会导致得到的耗时不准确。
发明内容
为了解决相关技术的问题,本发明实施例提供了一种启动项耗时的测量方法及装置。所述技术方案如下:
第一方面,提供了一种启动项耗时的测量方法,该方法包括:
开机完成后,读取性能监控日志中记录的原始数据,原始数据为在开机阶段启动各个启动项时记录的数据;
根据原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序;
根据每个启动项的资源占用率和启动顺序调整启动项的启动耗时。
第二方面,提供了一种启动项耗时的测量装置,该装置包括:
数据读取模块,用于开机完成后,读取性能监控日志中记录的原始数据,原始数据为在开机阶段启动各个启动项时记录的数据;
数据确定模块,用于根据数据读取模块读取的原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序;
耗时调整模块,用于根据数据确定模块确定的每个启动项的资源占用率和启动顺序调整启动项的启动耗时。
本发明实施例提供的技术方案带来的有益效果是:
通过根据原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序;根据每个启动项的资源占用率和启动顺序调整启动项的启动耗时,使得在先启动的启动项占用了过多的资源,而增加了在后启动的启动项的启动耗时时,可以根据启动顺序在前的启动项的资源占用率调整启动顺序在后的启动项的启动耗时,以使调整后的启动耗时更加接近该启动项在资源未被过多占用时实际的启动耗时,解决了相关技术中仅将启动项对应的进程占用CPU的时长确定为启动项在开机阶段的启动耗时,导致的确定的启动耗时不准确的问题,达到了提高确定的启动耗时的准确性的效果。
附图说明
为了更清楚地说明本发明实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是根据一个示例性实施例示出的一种启动项耗时的测量方法流程图;
图2是根据一个示例性实施例示出的一种启动项耗时的测量方法流程图;
图3是根据一个示例性实施例示出的第一种对优化建议进行显示的示意图;
图4是根据一个示例性实施例示出的第一种对优化建议进行显示的示意图;
图5是根据一个示例性实施例示出的一种启动项耗时的测量装置的框图;
图6是根据一个示例性实施例示出的一种启动项耗时的测量装置的框图;
图7是根据一个示例性实施例示出的一种启动项耗时的测量装置的结构方框图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本发明相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本发明的一些方面相一致的装置和方法的例子。
请参考图1,其示出了本发明一个实施例提供的启动项耗时的测量方法的流程图,本实施例以该启动项耗时的测量方法应用于终端中来举例说明。该启动项耗时的测量方法可以包括但不限于以下步骤:
步骤101,开机完成后,读取性能监控日志中记录的原始数据。
原始数据为在开机阶段启动各个启动项时记录的数据。
步骤102,根据原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序。
步骤103,根据每个启动项的资源占用率和启动顺序调整启动项的启动耗时。
综上所述,本发明实施例提供的启动项耗时的测量方法,通过根据原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序;根据每个启动项的资源占用率和启动顺序调整启动项的启动耗时,使得终端在逐一启动各个启动项时,若由于在先启动的启动项占用了过多的资源,导致在后启动的启动项的启动耗时增加,可以根据启动顺序在前的启动项的资源占用率,调整启动顺序在后的启动项的启动耗时,以使调整后的启动耗时更加接近该启动项实际的启动耗时,解决了相关技术中仅将启动项对应的进程占用CPU的时长确定为启动项在开机阶段的启动耗时,导致的确定的启动耗时不准确的问题,达到了提高确定的启动耗时的准确性的效果。
请参考图2,其示出了本发明一个实施例提供的启动项耗时的测量方法的流程图,本实施例以该启动项耗时的测量方法应用于终端中来举例说明,该终端中安装有追踪程序,该追踪程序可以在终端的开机阶段,对各个启动项进行监控。该启动项耗时的测量方法可以包括但不限于以下步骤:
步骤201,在上次关机时,调用预设的追踪程序。
若终端在本次开机时调用追踪程序,由于启动该追踪程序需要一段时间,且终端在开机阶段是顺序启动各个启动项的,即,一个启动项启动完成后再启动下一个启动项,因此,跟踪程序自身的启动耗时会影响在该追踪程序之后启动的启动项的启动耗时,并且,追踪程序无法对在自身之前启动的启动项进行监控。
本实施例中,在上次关机时,终端调用预设的追踪程序,由于追踪程序从上次关机至本次开机的过程中持续处于运行状态,因此,终端在本次开机时无需启动该追踪程序,不会对各个启动项的启动耗时产生影响,且追踪程序可以对所有的启动项进行监控,提高了监控各个启动项的启动耗时的准确性。
在实际实现时,该追踪程序可以为ETW API(Event Tracing for WindowsApplication Programming Interface,Windows事件追踪应用程序编程接口);或者,该追踪程序还可以为挂钩程序,本实施例不作限定。下文以追踪程序为ETW API进行举例说明。
ETW API由Provider API,Consumer API和Controller API三个部分组成,其中,Controller用于选择Provider,控制Provider开始追踪启动项的时机和停止追踪启动项的时机,以及将性能监控日志写入到指定的预设文件中,并将预设文件的地址通知给Consumer;每个Provider用于追踪一个或多个启动项,终端中预设的Provider的数量为多个;Consumer用于根据Controller通知的预设文件的地址解析预设文件。
步骤202,在本次开机时,利用追踪程序将生成的性能监控日志写入到预设文件中,并在性能监控日志中记录各个启动项的原始数据。
终端在本次开机时,调用Controller API将生成的性能监控日志写入到预设文件中,并调用Provider API将追踪各个启动项得到的原始数据记录在该预设文件中的性能监控日志中,该预设文件是Controller指定的文件,该原始数据为在开机阶段启动各个启动项时记录的数据,包括:启动项的资源占用率、开始启动的时间、启动完成的时间、启动顺序,资源占用率包括中央处理器CPU占用率、内存占用率、IO占用率中的一种或多种。
步骤203,开机完成后,读取性能监控日志中记录的原始数据。
终端调用Consumer API解析预设文件,得到性能监控日志中记录的原始数据。
步骤204,根据原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序。
对于每个启动项,终端读取原始数据中记录的该启动项的资源占用率、开始启动的时间、启动完成的时间及启动顺序,将启动完成的时间减去开始启动的时间,得到该启动项的启动耗时。
步骤205,根据每个启动项的资源占用率和启动顺序调整启动项的启动耗时。
具体地,根据每个启动项的资源占用率和启动顺序调整启动项的启动耗时,包括:
根据启动顺序确定第n个启动项,获取在第n个启动项之前启动的n-1个启动项的资源占用率,根据n-1个资源占用率调小第n个启动项的启动耗时,将n更新为n+1,继续执行根据启动顺序确定第n个启动项的步骤,n≥2。
其中,调小第n个启动项的启动耗时,第一种实现方式为:将第n个启动项的启动耗时减去预设数值,该预设数值的大小与前n-1个启动项的资源占用率的大小呈正相关关系;第二种实现方式为:将第n个启动项的启动耗时乘以小于1的预设系数,该预设系数的大小与前n-1个启动项的资源占用率的大小呈负相关关系。
若前n-1个启动项占用了过多的资源,则计算出的第n个启动项的启动耗时会比未被占用过多资源时实际的启动耗时大,通过调小计算出的第n个启动项的启动耗时,可以提高终端测量启动项的启动耗时的准确性。
假设第一个启动项的开始启动的时间为第0s,启动完成的时间为第0.5s,,则第一个启动项的启动耗时为0.5s;第二个启动项的开始启动的时间为第0.5s,启动完成的时间为第0.8s,则第二个启动项的启动耗时为0.3s;若第一个启动项的CPU占用率为40%,第二个启动项的CPU占用率为10%,由于第一个启动项占用了过多的CPU资源,可能会导致第二个启动项的启动耗时增大,此时,将第二个启动项的启动耗时乘以较小的预设系数0.5,得到调整后的启动耗时为0.15s。
在得到各个启动项的启动耗时后,还可以将各个启动项的启动耗时提供给用户,以便用户根据启动耗时确定是否在开机阶段禁止启动该启动项,以提高开机速度。可选的,终端可以将各个启动项按照启动耗时由大到小的顺序进行显示。
步骤206,检测是否显示优化建议,在检测出显示优化建议时,执行步骤207。
可选的,终端可以根据各个启动项的启动耗时生成优化建议,通过优化建议来建议用户禁止启动哪些启动项和允许启动哪些启动项,使得用户可以根据该优化建议快速地确定出需要禁用的启动项,提高了禁用启动项的效率。
具体地,终端可以检测用户是否触发了显示优化建议的选项,在用户触发了显示优化建议的选项时显示优化建议;或者,终端还可以检测启动耗时超过预设阈值的启动项的数量是否达到预设数量,在达到预设数量时显示优化建议,本实施例不对检测条件作限定。
步骤207,在检测出显示优化建议时,获取配置文件。
配置文件是服务器预先下发给终端的,该配置文件用于记录白名单项和黑名单项。可选的,服务器可以根据用户反馈的意见周期性地对配置文件中的各个白名单项和各个黑名单项进行更新,并将更新后的配置文件重新下发到终端中。其中,白名单项为在开机阶段禁止启动时,系统无法运行的启动项;黑名单项为耗时超过预设阈值的启动项,或者,黑名单项为启动后使得在后启动的启动项的耗时超过预设阈值的启动项。
步骤208,根据配置文件确定各个启动项所属的分类。
分类包括白名单类和黑名单类,白名单类为白名单项所属的分类,黑名单类为黑名单项所属的分类。分类后得到的白名单类中的各个启动项为建议保留的启动项,黑名单类中的各个启动项为建议禁止的启动项。
步骤209,根据各个启动项的启动耗时和每个启动项所属的分类生成优化建议。
优化建议中,每条启动项的显示信息包括该启动项的耗时和该启动项所属的分类。
步骤210,对生成的优化建议进行显示。
终端对生成的优化建议进行显示,使得用户可以根据该优化建议选择禁用的启动项,以提高终端的开机速度。
在显示优化建议时,可以将分类为白名单类的各个启动项按照启动耗时由大到小的顺序进行显示,将分类为黑名单类的各个启动项按照启动耗时由大到小的顺序进行显示。
例如:请参考图3,其示出了第一种终端显示的优化建议31,分类为白名单类32的各个启动项按照耗时由大到小的顺序显示在终端中,分类为黑名单类33的各个启动项按照耗时由大到小的顺序显示在终端中。
可选的,在显示优化建议时,还可以将各个启动项按照启动耗时由大到小的顺序进行显示,且在每个启动项的显示区域中显示该启动项所属的分类。
例如:请参考图4,其示出了第二种终端显示的优化建议41,各个启动项按照启动耗时由大到小的顺序进行显示,每个启动项的显示区域中显示该启动项所属的分类42,本例中将分类以字符的形式进行显示来举例说明,在实际实现时,也可以将分类以颜色、图案等其他形式进行显示,本例不作限定。
综上所述,本发明实施例提供的启动项耗时的测量方法,通过根据原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序;根据每个启动项的资源占用率和启动顺序调整启动项的启动耗时,使得在先启动的启动项占用了过多的资源,而增加了在后启动的启动项的启动耗时时,可以根据启动顺序在前的启动项的资源占用率调整启动顺序在后的启动项的启动耗时,以使调整后的启动耗时更加接近该启动项在资源未被过多占用时实际的启动耗时,解决了相关技术中仅将启动项对应的进程占用CPU的时长确定为启动项在开机阶段的启动耗时,导致的确定的启动耗时不准确的问题,达到了提高确定的启动耗时的准确性的效果。
另外,通过根据配置文件中的白名单项和黑名单项确定各个启动项所属的分类,根据各个启动项的启动耗时和每个启动项所属的分类生成优化建议,使得用户可以根据优化建议获知需要禁用的启动项以及不能禁用的启动项,既提高了禁用启动项的效率,又保证了系统能够正常运行。
另外,通过将各个启动项按照启动耗时由大到小的顺序进行显示,使得用户可以快速定位出启动耗时较大的启动项,提高禁用启动耗时大的启动项的效率。
请参考图5,其示出了本发明一个实施例提供的启动项耗时的测量装置的框图,本实施例以该启动项耗时的测量装置应用于终端中来举例说明,该启动项耗时的测量装置可以包括但不限于以下模块:数据读取模块510、数据确定模块520、耗时调整模块530。
该数据读取模块510,用于开机完成后,读取性能监控日志中记录的原始数据,原始数据为在开机阶段启动各个启动项时记录的数据;
该数据确定模块520,用于根据数据读取模块510读取的原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序;
该耗时调整模块530,用于根据数据确定模块520确定的每个启动项的资源占用率和启动顺序调整启动项的启动耗时。
综上所述,本发明实施例提供的启动项耗时的测量装置,通过根据原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序;根据每个启动项的资源占用率和启动顺序调整启动项的启动耗时,使得终端可以根据每个启动项的启动顺序,以及,先前启动的启动项占用的资源,来测量该启动项的启动耗时,解决了相关技术中仅将启动项对应的进程占用CPU的时长确定为启动项在开机阶段的启动耗时,导致的确定的启动耗时不准确的问题,达到了提高确定的启动耗时的准确性的效果。
请参考图6,其示出了本发明一个实施例提供的启动项耗时的测量装置的框图,本实施例以该启动项耗时的测量装置应用于终端中来举例说明,该启动项耗时的测量装置可以包括但不限于以下模块:数据读取模块610、数据确定模块620、耗时调整模块630。
该数据读取模块610,用于开机完成后,读取性能监控日志中记录的原始数据,原始数据为在开机阶段启动各个启动项时记录的数据;
该数据确定模块620,用于根据数据读取模块610读取的原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序;
该耗时调整模块630,用于根据数据确定模块620确定的每个启动项的资源占用率和启动顺序调整启动项的启动耗时。
可选的,原始数据包括启动项的资源占用率、开始启动的时间、启动完成的时间、启动顺序,资源占用率包括中央处理器CPU占用率、内存占用率、磁盘输入输出IO占用率中的一种或多种,
该数据确定模块620,还用于对于每个启动项,读取原始数据中启动项的资源占用率、开始启动的时间、启动完成的时间及启动顺序,根据开始启动的时间和启动完成的时间确定启动项的启动耗时;
该耗时调整模块630,还用于根据启动顺序确定第n个启动项,获取在第n个启动项之前启动的n-1个启动项的资源占用率,根据n-1个资源占用率调小第n个启动项的启动耗时,将n更新为n+1,继续执行根据启动顺序确定第n个启动项的步骤,n≥2。
可选的,该装置还包括:检测模块640、获取模块650、分类确定模块660、生成模块670。
该检测模块640,用于检测是否显示优化建议,优化建议包括建议保留的启动项和禁用的启动项;
该获取模块650,用于在检测模块640检测出显示优化建议时,获取配置文件,配置文件用于记录白名单项和黑名单项,白名单项为在开机阶段禁止启动时,系统无法运行的启动项,黑名单项为耗时超过预设阈值的启动项,或者,黑名单项为启动后使得在后启动的启动项的耗时超过预设阈值的启动项;
该分类确定模块660,用于根据获取模块650获取的配置文件确定各个启动项所属的分类,分类包括白名单类和黑名单类;
该生成模块670,用于根据各个启动项的启动耗时和分类确定模块660确定的每个启动项所属的分类生成优化建议。
可选的,该装置还包括:第一显示模块680、第二显示模块690。
该第一显示模块680,用于在根据各个启动项的启动耗时和每个启动项所属的分类生成优化建议之后,将各个启动项按照启动耗时由大到小的顺序进行显示;或者,
该第二显示模块690,用于在根据各个启动项的启动耗时和每个启动项所属的分类生成优化建议之后,将分类为白名单类的各个启动项按照启动耗时由大到小的顺序进行显示,将分类为黑名单类的各个启动项按照启动耗时由大到小的顺序进行显示。
可选的,该装置还包括:程序调用模块691、数据记录模块692。
该程序调用模块691,用于在开机完成后,读取性能监控日志中记录的原始数据之前,在上次关机时,调用预设的追踪程序,追踪程序从上次关机至本次开机的过程中持续处于运行状态;
该数据记录模块692,用于在开机完成后,读取性能监控日志中记录的原始数据之前,在本次开机时,利用程序调用模块691调用的追踪程序将生成的性能监控日志写入到预设文件中,并在性能监控日志中记录各个启动项的原始数据。
综上所述,本发明实施例提供的启动项耗时的测量装置,通过根据原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序;根据每个启动项的资源占用率和启动顺序调整启动项的启动耗时,使得在先启动的启动项占用了过多的资源,而增加了在后启动的启动项的启动耗时时,可以根据启动顺序在前的启动项的资源占用率调整启动顺序在后的启动项的启动耗时,以使调整后的启动耗时更加接近该启动项在资源未被过多占用时实际的启动耗时,解决了相关技术中仅将启动项对应的进程占用CPU的时长确定为启动项在开机阶段的启动耗时,导致的确定的启动耗时不准确的问题,达到了提高确定的启动耗时的准确性的效果。
另外,通过根据配置文件中的白名单项和黑名单项确定各个启动项所属的分类,根据各个启动项的启动耗时和每个启动项所属的分类生成优化建议,使得用户可以根据优化建议获知需要禁用的启动项,以及不能禁用的启动项,既提高了禁用启动项的效率,又保证了系统能够正常运行。
另外,通过将各个启动项按照启动耗时由大到小的顺序进行显示,使得用户可以快速定位出启动耗时较大的启动项,提高禁用启动耗时大的启动项的效率。
需要说明的是:上述实施例中提供的启动项耗时的测量装置在测量启动耗时时,仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将终端的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。另外,上述实施例提供的启动项耗时的测量装置与启动项耗时的测量方法实施例属于同一构思,其具体实现过程详见方法实施例,这里不再赘述。
请参见图7所示,其示出了本发明部分实施例中提供的终端的结构方框图。该终端700用于实施上述实施例提供的启动项耗时的测量方法。本发明中的终端700可以包括一个或多个如下组成部分:用于执行计算机程序指令以完成各种流程和方法的处理器,用于信息和存储程序指令随机接入存储器(RAM)和只读存储器(ROM),用于存储数据和信息的存储器,I/O设备,界面,天线等。具体来讲:
终端700可以包括RF(Radio Frequency,射频)电路710、存储器720、输入单元730、显示单元740、传感器750、音频电路760、WiFi(wireless fidelity,无线保真)模块770、处理器780、电源782、摄像头790等部件。本领域技术人员可以理解,图7中示出的终端结构并不构成对终端的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
下面结合图7对终端700的各个构成部件进行具体的介绍:
RF电路710可用于收发信息或通话过程中,信号的接收和发送,特别地,将基站的下行信息接收后,给处理器780处理;另外,将设计上行的数据发送给基站。通常,RF电路包括但不限于天线、至少一个放大器、收发信机、耦合器、LNA(Low Noise Amplifier,低噪声放大器)、双工器等。此外,RF电路710还可以通过无线通信与网络和其他设备通信。所述无线通信可以使用任一通信标准或协议,包括但不限于GSM(Global System of Mobile communication,全球移动通讯系统)、GPRS(General Packet Radio Service,通用分组无线服务)、CDMA(Code Division Multiple Access,码分多址)、WCDMA(Wideband CodeDivision Multiple Access,宽带码分多址)、LTE(Long Term Evolution,长期演进)、电子邮件、SMS(Short Messaging Service,短消息服务)等。
存储器720可用于存储软件程序以及模块,处理器780通过运行存储在存储器720的软件程序以及模块,从而执行终端700的各种功能应用以及数据处理。存储器720可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、跟踪程序、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据终端700的使用所创建的数据(比如跟踪程序跟踪各个启动项得到的原始数据)等。此外,存储器720可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
输入单元730可用于接收输入的数字或字符信息,以及产生与终端700的用户设置以及功能控制有关的键信号输入。具体地,输入单元730可包括触控面板731以及其他输入设备732。触控面板731,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板731上或在触控面板731附近的操作),并根据预先设定的程式驱动相应的连接装置。可选的,触控面板731可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器780,并能接收处理器780发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板731。除了触控面板731,输入单元730还可以包括其他输入设备732。具体地,其他输入设备732可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种。
显示单元740可用于显示由用户输入的信息或提供给用户的信息以及终端700的各种菜单。显示单元740可包括显示面板741,可选的,可以采用LCD(Liquid Crystal Display,液晶显示器)、OLED(Organic Light-Emitting Diode,有机发光二极管)等形式来配置显示面板741。进一步的,触控面板731可覆盖显示面板741,当触控面板731检测到在其上或附近的触摸操作后,传送给处理器780以确定触摸事件的类型,随后处理器780根据触摸事件的类型在显示面板741上提供相应的视觉输出。虽然在图7中,触控面板731与显示面板741是作为两个独立的部件来实现终端700的输入和输入功能,但是在某些实施例中,可以将触控面板731与显示面板741集成而实现终端700的输入和输出功能。
终端700还可包括至少一种传感器750,比如陀螺仪传感器、磁感应传感器、光传感器、运动传感器以及其他传感器。具体地,光传感器可包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板741的亮度,接近传感器可在终端700移动到耳边时,关闭显示面板741和/或背光。作为运动传感器的一种,加速度传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别终端姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于终端700还可配置的气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。
音频电路760、扬声器761,传声器762可提供用户与终端700之间的音频接口。音频电路760可将接收到的音频数据转换后的电信号,传输到扬声器761,由扬声器761转换为声音信号输出;另一方面,传声器762将收集的声音信号转换为电信号,由音频电路760接收后转换为音频数据,再将音频数据输出处理器780处理后,经RF电路710以发送给比如另一终端,或者将音频数据输出至存储器720以便进一步处理。
WiFi属于短距离无线传输技术,终端700通过WiFi模块770可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图7示出了WiFi模块770,但是可以理解的是,其并不属于终端700的必须构成,完全可以根据需要在不改变公开的本质的范围内而省略。
处理器780是终端700的控制中心,利用各种接口和线路连接整个终端的各个部分,通过运行或执行存储在存储器720内的软件程序和/或模块,以及调用存储在存储器720内的数据,执行终端700的各种功能和处理数据,从而对终端进行整体监控。可选的,处理器780可包括一个或多个处理单元;优选的,处理器780可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器780中。
终端700还包括给各个部件供电的电源782(比如电池),优选的,电源可以通过电源管理系统与处理器782逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。
摄像头790一般由镜头、图像传感器、接口、数字信号处理器、CPU、显示屏幕等组成。其中,镜头固定在图像传感器的上方,可以通过手动调节镜头来改变聚焦;图像传感器相当于传统相机的“胶卷”,是摄像头采集图像的心脏;接口用于把摄像头利用排线、板对板连接器、弹簧式连接方式与终端主板连接,将采集的图像发送给所述存储器720;数字信号处理器通过数学运算对采集的图像进行处理,将采集的模拟图像转换为数字图像并通过接口发送给存储器720。
尽管未示出,终端700还可以包括蓝牙模块等,在此不再赘述。
本领域普通技术人员可以理解实现上述实施例的全部或部分步骤可以通过硬件来完成,也可以通过程序来指令相关的硬件完成,所述的程序可以存储于一种计算机可读存储介质中,上述提到的存储介质可以是只读存储器,磁盘或光盘等。
以上所述仅为本发明的较佳实施例,并不用以限制本发明,凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。
Claims (10)
1.一种启动项耗时的测量方法,其特征在于,所述方法包括:
开机完成后,读取性能监控日志中记录的原始数据,所述原始数据为在开机阶段启动各个启动项时记录的数据;
根据所述原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序;
根据每个启动项的资源占用率和启动顺序调整所述启动项的启动耗时。
2.根据权利要求1所述的方法,其特征在于,所述原始数据包括启动项的资源占用率、开始启动的时间、启动完成的时间、启动顺序,所述资源占用率包括中央处理器CPU占用率、内存占用率、磁盘输入输出IO占用率中的一种或多种,
所述根据所述原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序,包括:
对于每个启动项,读取所述原始数据中所述启动项的资源占用率、开始启动的时间、启动完成的时间及启动顺序,根据所述开始启动的时间和所述启动完成的时间确定所述启动项的启动耗时;
所述根据每个启动项的资源占用率和启动顺序调整所述启动项的启动耗时,包括:
根据启动顺序确定第n个启动项,获取在所述第n个启动项之前启动的n-1个启动项的资源占用率,根据n-1个资源占用率调小所述第n个启动项的启动耗时,将n更新为n+1,继续执行所述根据启动顺序确定第n个启动项的步骤,n≥2。
3.根据权利要求1所述的方法,其特征在于,所述方法还包括:
检测是否显示优化建议,所述优化建议包括建议保留的启动项和禁用的启动项;
在检测出显示所述优化建议时,获取配置文件,所述配置文件用于记录白名单项和黑名单项,所述白名单项为在开机阶段禁止启动时,系统无法运行的启动项,所述黑名单项为耗时超过预设阈值的启动项,或者,所述黑名单项为启动后使得在后启动的启动项的耗时超过预设阈值的启动项;
根据所述配置文件确定各个启动项所属的分类,所述分类包括白名单类和黑名单类;
根据各个启动项的启动耗时和每个启动项所属的分类生成所述优化建议。
4.根据权利要求3所述的方法,其特征在于,所述根据各个启动项的启动耗时和每个启动项所属的分类生成所述优化建议之后,还包括:
将各个启动项按照启动耗时由大到小的顺序进行显示;或者,
将分类为白名单类的各个启动项按照启动耗时由大到小的顺序进行显示,将分类为黑名单类的各个启动项按照启动耗时由大到小的顺序进行显示。
5.根据权利要求1至4任一所述的方法,其特征在于,所述开机完成后,读取性能监控日志中记录的原始数据之前,还包括:
在上次关机时,调用预设的追踪程序,所述追踪程序从上次关机至本次开机的过程中持续处于运行状态;
在本次开机时,利用所述追踪程序将生成的性能监控日志写入到预设文件中,并在所述性能监控日志中记录各个启动项的原始数据。
6.一种启动项耗时的测量装置,其特征在于,所述装置包括:
数据读取模块,用于开机完成后,读取性能监控日志中记录的原始数据,所述原始数据为在开机阶段启动各个启动项时记录的数据;
数据确定模块,用于根据所述数据读取模块读取的所述原始数据确定各个启动项在开机阶段的资源占用率、启动耗时及启动顺序;
耗时调整模块,用于根据所述数据确定模块确定的每个启动项的资源占用率和启动顺序调整所述启动项的启动耗时。
7.根据权利要求6所述的装置,其特征在于,所述原始数据包括启动项的资源占用率、开始启动的时间、启动完成的时间、启动顺序,所述资源占用率包括中央处理器CPU占用率、内存占用率、磁盘输入输出IO占用率中的一种或多种,
所述数据确定模块,还用于对于每个启动项,读取所述原始数据中所述启动项的资源占用率、开始启动的时间、启动完成的时间及启动顺序,根据所述开始启动的时间和所述启动完成的时间确定所述启动项的启动耗时;
所述耗时调整模块,还用于根据启动顺序确定第n个启动项,获取在所述第n个启动项之前启动的n-1个启动项的资源占用率,根据n-1个资源占用率调小所述第n个启动项的启动耗时,将n更新为n+1,继续执行所述根据启动顺序确定第n个启动项的步骤,n≥2。
8.根据权利要求6所述的装置,其特征在于,所述装置还包括:
检测模块,用于检测是否显示优化建议,所述优化建议包括建议保留的启动项和禁用的启动项;
获取模块,用于在所述检测模块检测出显示所述优化建议时,获取配置文件,所述配置文件用于记录白名单项和黑名单项,所述白名单项为在开机阶段禁止启动时,系统无法运行的启动项,所述黑名单项为耗时超过预设阈值的启动项,或者,所述黑名单项为启动后使得在后启动的启动项的耗时超过预设阈值的启动项;
分类确定模块,用于根据所述获取模块获取的所述配置文件确定各个启动项所属的分类,所述分类包括白名单类和黑名单类;
生成模块,用于根据各个启动项的启动耗时和所述分类确定模块确定的每个启动项所属的分类生成所述优化建议。
9.根据权利要求8所述的装置,其特征在于,所述装置还包括:
第一显示模块,用于在所述生成模块根据各个启动项的启动耗时和每个启动项所属的分类生成所述优化建议之后,将各个启动项按照启动耗时由大到小的顺序进行显示;或者,
第二显示模块,用于在所述生成模块根据各个启动项的启动耗时和每个启动项所属的分类生成所述优化建议之后,将分类为白名单类的各个启动项按照启动耗时由大到小的顺序进行显示,将分类为黑名单类的各个启动项按照启动耗时由大到小的顺序进行显示。
10.根据权利要求6至9任一所述的装置,其特征在于,所述装置还包括:
程序调用模块,用于在开机完成后,所述数据读取模块读取性能监控日志中记录的原始数据之前,在上次关机时,调用预设的追踪程序,所述追踪程序从上次关机至本次开机的过程中持续处于运行状态;
数据记录模块,用于在本次开机时,利用所述程序调用模块调用的所述追踪程序将生成的性能监控日志写入到预设文件中,并在所述性能监控日志中记录各个启动项的原始数据。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610281655.XA CN107341094B (zh) | 2016-04-29 | 2016-04-29 | 启动项耗时的测量方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610281655.XA CN107341094B (zh) | 2016-04-29 | 2016-04-29 | 启动项耗时的测量方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN107341094A true CN107341094A (zh) | 2017-11-10 |
CN107341094B CN107341094B (zh) | 2020-01-31 |
Family
ID=60222789
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201610281655.XA Active CN107341094B (zh) | 2016-04-29 | 2016-04-29 | 启动项耗时的测量方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN107341094B (zh) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111708581A (zh) * | 2020-05-13 | 2020-09-25 | 北京梧桐车联科技有限责任公司 | 应用启动方法、装置、设备及计算机存储介质 |
TWI710957B (zh) * | 2019-05-20 | 2020-11-21 | 宏碁股份有限公司 | 加速開機系統及加速開機方法 |
CN112114878A (zh) * | 2019-06-21 | 2020-12-22 | 宏碁股份有限公司 | 加速开机系统及加速开机方法 |
CN115080151A (zh) * | 2022-07-22 | 2022-09-20 | 平安银行股份有限公司 | App启动流程控制方法、计算机可读存储介质及终端 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20120089797A1 (en) * | 2010-10-08 | 2012-04-12 | Hitachi, Ltd. | Computer system, storage management computer, and storage management method |
CN102591770A (zh) * | 2011-12-27 | 2012-07-18 | 奇智软件(北京)有限公司 | 一种目标应用启动时间检测方法和装置 |
CN103150248A (zh) * | 2013-03-22 | 2013-06-12 | 腾讯科技(深圳)有限公司 | 一种启动项耗时的测算方法和装置 |
CN104360885A (zh) * | 2014-11-18 | 2015-02-18 | 深圳市中兴移动通信有限公司 | 一种启动控制方法、装置及终端 |
CN104461725A (zh) * | 2014-12-30 | 2015-03-25 | 小米科技有限责任公司 | 控制应用进程启动的方法及装置 |
-
2016
- 2016-04-29 CN CN201610281655.XA patent/CN107341094B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20120089797A1 (en) * | 2010-10-08 | 2012-04-12 | Hitachi, Ltd. | Computer system, storage management computer, and storage management method |
CN102591770A (zh) * | 2011-12-27 | 2012-07-18 | 奇智软件(北京)有限公司 | 一种目标应用启动时间检测方法和装置 |
CN103150248A (zh) * | 2013-03-22 | 2013-06-12 | 腾讯科技(深圳)有限公司 | 一种启动项耗时的测算方法和装置 |
CN104360885A (zh) * | 2014-11-18 | 2015-02-18 | 深圳市中兴移动通信有限公司 | 一种启动控制方法、装置及终端 |
CN104461725A (zh) * | 2014-12-30 | 2015-03-25 | 小米科技有限责任公司 | 控制应用进程启动的方法及装置 |
Cited By (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
TWI710957B (zh) * | 2019-05-20 | 2020-11-21 | 宏碁股份有限公司 | 加速開機系統及加速開機方法 |
US11663470B2 (en) | 2019-05-20 | 2023-05-30 | Acer Incorporated | Method and system for accelerating boot time |
CN112114878A (zh) * | 2019-06-21 | 2020-12-22 | 宏碁股份有限公司 | 加速开机系统及加速开机方法 |
CN112114878B (zh) * | 2019-06-21 | 2024-03-12 | 宏碁股份有限公司 | 加速开机系统及加速开机方法 |
CN111708581A (zh) * | 2020-05-13 | 2020-09-25 | 北京梧桐车联科技有限责任公司 | 应用启动方法、装置、设备及计算机存储介质 |
CN111708581B (zh) * | 2020-05-13 | 2024-01-26 | 北京梧桐车联科技有限责任公司 | 应用启动方法、装置、设备及计算机存储介质 |
CN115080151A (zh) * | 2022-07-22 | 2022-09-20 | 平安银行股份有限公司 | App启动流程控制方法、计算机可读存储介质及终端 |
CN115080151B (zh) * | 2022-07-22 | 2023-07-14 | 平安银行股份有限公司 | App启动流程控制方法、计算机可读存储介质及终端 |
Also Published As
Publication number | Publication date |
---|---|
CN107341094B (zh) | 2020-01-31 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107800651B (zh) | 应用程序关闭方法、装置、存储介质和电子设备 | |
CN107734616B (zh) | 应用程序关闭方法、装置、存储介质和电子设备 | |
JP6955092B2 (ja) | 端末の電力消費を低減するための方法、および端末 | |
CN104967896A (zh) | 一种显示弹幕评论信息的方法和装置 | |
US10474507B2 (en) | Terminal application process management method and apparatus | |
WO2017206902A1 (zh) | 应用控制方法及相关设备 | |
CN106294168B (zh) | 一种进行应用程序测试的方法和系统 | |
CN107562539B (zh) | 应用程序处理方法和装置、计算机设备、存储介质 | |
CN106775828B (zh) | 应用程序安装方法及装置、计算机设备 | |
CN107734618B (zh) | 应用程序关闭方法、装置、存储介质和电子设备 | |
CN115668123A (zh) | 一种音频资源分配方法、装置和电子设备 | |
CN107341094A (zh) | 启动项耗时的测量方法及装置 | |
CN108564539B (zh) | 一种显示图像的方法和装置 | |
CN111273955B (zh) | 热修复插件优化方法、装置、存储介质及电子设备 | |
CN110930964B (zh) | 一种显示屏亮度调节方法、装置、存储介质及终端 | |
CN114565070A (zh) | 一种标签绑定方法、装置及移动终端 | |
CN110767950B (zh) | 充电方法、装置、终端设备及计算机可读存储介质 | |
CN112749074A (zh) | 一种测试用例推荐方法以及装置 | |
CN106302101B (zh) | 消息提醒方法、终端及服务器 | |
CN107832131B (zh) | 应用程序关闭方法、装置、存储介质和电子设备 | |
CN107622234B (zh) | 一种显示萌脸礼物的方法和装置 | |
CN112612552A (zh) | 应用程序资源加载方法、装置、电子设备及可读存储介质 | |
CN111404242A (zh) | 充电方法、装置、存储介质及移动终端 | |
CN108269223B (zh) | 一种网页图形绘制方法及终端 | |
CN106201202B (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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |