CN110333969A - 系统升级后应用启动异常处理方法及装置、介质和设备 - Google Patents

系统升级后应用启动异常处理方法及装置、介质和设备 Download PDF

Info

Publication number
CN110333969A
CN110333969A CN201910522083.3A CN201910522083A CN110333969A CN 110333969 A CN110333969 A CN 110333969A CN 201910522083 A CN201910522083 A CN 201910522083A CN 110333969 A CN110333969 A CN 110333969A
Authority
CN
China
Prior art keywords
target application
file
executable file
starting
eliminating method
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
Application number
CN201910522083.3A
Other languages
English (en)
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.)
Guangdong Oppo Mobile Telecommunications Corp 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 CN201910522083.3A priority Critical patent/CN110333969A/zh
Publication of CN110333969A publication Critical patent/CN110333969A/zh
Pending legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/14Error detection or correction of the data by redundancy in operation
    • G06F11/1402Saving, restoring, recovering or retrying
    • G06F11/1415Saving, restoring, recovering or retrying at system level
    • G06F11/1433Saving, restoring, recovering or retrying at system level during software upgrading
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • 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/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • 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/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45562Creating, deleting, cloning virtual machine instances

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Quality & Reliability (AREA)
  • Computer Security & Cryptography (AREA)
  • Stored Programmes (AREA)

Abstract

本发明公开了一种系统升级后应用启动异常处理方法、系统升级后应用启动异常处理装置、存储介质和电子设备,涉及计算机技术领域。该系统升级后应用启动异常处理方法包括:在系统升级后,获取目标应用的可执行文件;将目标应用的可执行文件转换为二进制文件;响应用户针对目标应用的启动操作,通过虚拟机加载二进制文件。本公开可以避免系统升级后应用启动时出现黑屏的问题。

Description

系统升级后应用启动异常处理方法及装置、介质和设备
技术领域
本公开涉及计算机技术领域,具体而言,涉及一种系统升级后应用启动异常处理方法、系统升级后应用启动异常处理装置、存储介质和电子设备。
背景技术
为了提升用户体验、增强系统的安全性和稳定性、推出更具备吸引力的新功能等目的,终端设备的各大厂商会发布系统更新,供用户进行升级选择。
在系统进行升级并重启后,当用户点击安装于终端设备上的应用时,终端设备可能会存在加载异常的问题,导致出现黑屏或应用闪退等异常情况,严重影响了用户的使用体验。
需要说明的是,在上述背景技术部分公开的信息仅用于加强对本公开的背景的理解,因此可以包括不构成对本领域普通技术人员已知的现有技术的信息。
发明内容
本公开的目的在于提供一种系统升级后应用启动异常处理方法、系统升级后应用启动异常处理装置、存储介质和电子设备,进而至少在一定程度上克服由于相关技术的限制和缺陷而导致的系统升级后应用启动出现黑屏或应用闪退等异常问题。
根据本公开的第一个方面,提供一种系统升级后应用启动异常处理方法,包括:在系统升级后,获取目标应用的可执行文件;将目标应用的可执行文件转换为二进制文件;响应用户针对目标应用的启动操作,通过虚拟机加载二进制文件。
根据本公开的第二个方面,提供一种系统升级后应用启动异常处理装置,包括:文件获取模块,用于在系统升级后,获取目标应用的可执行文件;文件转换模块,用于将目标应用的可执行文件转换为二进制文件;文件加载模块,用于响应用户针对目标应用的启动操作,通过虚拟机加载二进制文件。
根据本公开的第三个方面,提供一种存储介质,其上存储有计算机程序,计算机程序被处理器执行时实现上述系统升级后应用启动异常处理方法。
根据本公开的第四个方面,提供一种电子设备,包括:处理器;以及存储器,用于存储处理器的可执行指令;其中,处理器配置为经由执行可执行指令来执行上述系统升级后应用启动异常处理方法。
在本公开的一些实施例所提供的技术方案中,在系统升级后,获取目标应用的可执行文件,并将可执行文件转换为二进制文件,并在响应用户针对目标应用的启动操作时,通过虚拟机加载二进制文件。本公开示例性实施方式通过在系统升级后主动将应用的可执行文件转换为计算机能够识别的二进制文件,在这种情况下,当应用启动时,可以直接获取转换的二进制文件,避免了相关技术中用户启动应用时读取旧版本文件而导致加载异常的问题,解决了应用启动时出现例如黑屏的问题,另外,用户使用体验的提升,有助于提高系统升级的用户接受度。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理。显而易见地,下面描述中的附图仅仅是本公开的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。在附图中:
图1示意性示出了根据本公开的示例性实施方式的系统升级后应用启动异常处理方法的流程图;
图2示出了本公开的一个实施例的终端设备界面显示等待提示信息的示意图;
图3示意性示出了根据本公开的示例性实施方式的系统升级后应用启动异常处理装置的方框图;
图4示意性示出了根据本公开的另一示例性实施方式的系统升级后应用启动异常处理装置的方框图;
图5示意性示出了根据本公开的示例性实施方式的文件获取模块的方框图;
图6示意性示出了根据本公开的又一示例性实施方式的系统升级后应用启动异常处理装置的方框图;
图7示意性示出了根据本公开的示例性实施方式的电子设备的方框图。
具体实施方式
现在将参考附图更全面地描述示例实施方式。然而,示例实施方式能够以多种形式实施,且不应被理解为限于在此阐述的范例;相反,提供这些实施方式使得本公开将更加全面和完整,并将示例实施方式的构思全面地传达给本领域的技术人员。所描述的特征、结构或特性可以以任何合适的方式结合在一个或更多实施方式中。在下面的描述中,提供许多具体细节从而给出对本公开的实施方式的充分理解。然而,本领域技术人员将意识到,可以实践本公开的技术方案而省略所述特定细节中的一个或更多,或者可以采用其它的方法、组元、装置、步骤等。在其它情况下,不详细示出或描述公知技术方案以避免喧宾夺主而使得本公开的各方面变得模糊。
此外,附图仅为本公开的示意性图解,并非一定是按比例绘制。图中相同的附图标记表示相同或类似的部分,因而将省略对它们的重复描述。附图中所示的一些方框图是功能实体,不一定必须与物理或逻辑上独立的实体相对应。可以采用软件形式来实现这些功能实体,或在一个或多个硬件模块或集成电路中实现这些功能实体,或在不同网络和/或处理器装置和/或微控制器装置中实现这些功能实体。
附图中所示的流程图仅是示例性说明,不是必须包括所有的步骤。例如,有的步骤还可以分解,而有的步骤可以合并或部分合并,因此实际执行的顺序有可能根据实际情况改变。
下面所述的系统升级可以指终端设备的系统升级,其中,终端设备可以包括但不限于手机、平板、智能穿戴设备、车载中控设备等,本示例性实施方式中对此不做特殊限定。另外,由于终端设备的研发、制造厂商不同,系统也存在差异,本公开示例性实施方式对系统的类型、架构、运行方式均不作特殊限定。
当系统进行OTA(Over-The-Air Technology,空间下载技术)升级后,如果用户启动应用,则由于应用无法识别系统是否进行升级,会直接加载该应用上一版本的二进制文件。然而,由于系统升级后,例如执行业务处理过程的数据(或函数)位置可能发生了变化,在执行应用的旧版本文件时,可能会出现加载异常的情况,导致出现黑屏或应用闪退等异常现象。
鉴于此,需要一种新的处理方式,以避免加载异常的情况发生。
下面所述的处理方法可以由终端设备实现,也就是说,可以由终端设备执行下面所述系统升级后应用启动异常处理方法的各个步骤,在这种情况下,系统升级后应用启动异常处理装置可以被配置于终端设备中。
图1示意性示出了本公开的示例性实施方式的系统升级后应用启动异常处理方法的流程图。参考图1,系统升级后应用启动异常处理方法可以包括以下步骤:
S12.在系统升级后,获取目标应用的可执行文件。
根据本公开的一些实施例,系统升级可以指OTA升级。其中,OTA升级作为一种标准升级方式,可以实现无损失升级系统,主要通过网络(例如,WiFi、4G流量等)下载OTA升级包,自动升级。另外,这种升级方式也支持通过下载OTA升级包到SD卡升级的模式。
然而,需要说明的是,本公开所述的升级不限于OTA升级,还可以利用电脑(个人计算机)进行升级,本公开对终端设备升级的方式以及升级的过程不做特殊限定。
本公开的一些实施例还可以包括检测系统是否升级的方案,具体的,可以通过检测升级标志位来确定系统是否升级,其中,升级标志位可以存储于终端设备的存储区内,是用于判定系统是否进行升级的变量。如果检测到该升级标志位相对于上一系统版本被修改,则确定出系统已升级。
另外,还可以通过检测系统的版本号来确定系统是否升级,本公开对检测系统升级的过程不作特殊限制。
在确定出系统升级后,系统首次启动时,可以获取目标应用的可执行文件。其中,目标应用可以是系统中任意一个应用。另外,可执行文件为应用运行时的解释文件,在将该可执行文件转换为机器能够识别的二进制文件后,终端设备才能正常运行应用。在本公开的示例性实施方式中,可执行文件是dex文件,二进制文件为oat文件。
针对获取目标应用的可执行文件的过程,首先,可以确定目标应用的优先处理等级,其中,优先处理等级可以用于表征获取应用的可执行文件的急切程度。具体的,可以确定一预设时间段内(例如,一周内,一月内等)目标应用相比于该预设时间段的运行时长占比,并根据运行时长占比确定目标应用的优先处理等级。其中,可以预设运行时长占比与优先处理等级的映射关系,如,运行时长占比大于等于0.7,则对应优先处理等级为1级;运行时长占比大于等于0.3且小于0.7,则对应优先处理等级为2级;运行时长占比小于0.3,则对应优先处理等级为3级。应当理解的是,运行时长占比与优先处理等级的映射关系还可以被设置为其他形式,优先处理等级的还可以被划分一共4级、5级等,本示例性实施方式中对此不做特殊限定。
接下来,可以优先将优先处理等级比目标应用高的应用的可执行文件转换为二进制文件后,才获取目标应用的可执行文件。具体的,可以判断目标应用的优先处理等级是否为1级(1级为最高级),如果为1级,则上述优先处理等级比目标应用高的应用集合可以被理解为空,也就是说,系统中没有比目标应用的优先处理等级高的应用。
例如,一周内,如果目标应用的运行时长占比为0.6,仍以上述为例,则可以确定优先处理等级为2级。则可以优先将优先处理等级为1级的应用的可执行文件转换为二进制文件,然后再获取目标应用的可执行文件。
此外,上面描述了在系统首次启动时获取目标应用的可执行文件的过程,然而,应当注意的是,还可以在系统其他启动时间(例如,第二次启动)时获取目标应用的可执行文件,例如,目标应用为用户不常用的应用,在这种情况下,可以在系统升级后第二次启动时,获取目标应用的可执行文件,由此,可以减轻在升级后第一次启动系统时运算资源的压力。
S14.将目标应用的可执行文件转换为二进制文件。
在本公开的示例性实施方式中,可执行文件为dex文件,在这种情况下,可以调用dex2oat编译程序将可执行文件转换为二进制文件,具体的,将dex文件转换为机器能够识别的oat文件。
S16.响应用户针对目标应用的启动操作,通过虚拟机加载二进制文件。
在将目标应用的可执行文件转换为二进制文件后,如果用户点击目标应用的图标,则终端设备可以响应该启动操作,通过虚拟机直接加载该二进制文件到内存中,以便迅速启动目标应用。
容易理解的是,此处所述的虚拟机为ART虚拟机。
此外,为了避免在将目标应用的可执行文件转换为二进制文件之前,用户点击目标应用的图标而仍可能造成黑屏的问题,本公开一些实施例提供了下述解决方案。
根据本公开的一个实施例,在将目标应用的可执行文件转换为二进制文件之前,如果接收到针对目标应用的启动指令,则控制目标应用暂停启动,直至完成将目标应用的可执行文件转换为二进制文件为止。控制目标应用暂停启动意指控制不执行加载目标应用的二进制文件的过程。在这些实施例中,可以按上述优先处理等级依次执行将应用的可执行文件转换为二进制文件的过程,直至完成目标应用的文件转换。
进一步的,在按优先处理等级依次执行应用的文件转换过程中,如果目标应用的优先处理等级较低,可能会出现需要较长时间来完成目标应用的文件转换过程。鉴于此,为了加快目标应用的文件转换的速度,本公开另一个实施例中还可以判断当前是否获取到目标应用的可执行文件,如果已获取到目标应用的可执行文件,则可以将目标应用的可执行文件转换为二进制文件,以便通过虚拟机加载二进制文件;如果未获取到目标应用的可执行文件,则可以不考虑优先处理等级,直接获取目标应用的可执行文件,并将目标应用的可执行文件转换为二进制文件,以便通过虚拟机加载二进制文件。
此外,根据本公开的另一些实施例,在与用户进行交互的显示界面上,可以呈现等待提示信息,直至完成将目标应用的可执行文件转换为二进制文件为止。
参考图2,以手机为例,手机系统升级并重启后,在用户点击应用6时,如果未获取到应用6的可执行文件,则在显示界面上,可以以子界面的形式显示等待提示信息,该提示信息可以例如为“应用更新中,请稍后”。虽然未示出,等待提示信息还可以是“应用准备中,请稍后”等文字。此外,还可以通过延长应用开启界面(例如,应用开启时的广告界面等)的时间等方式来实现显示前端的处理,本示例性实施方式中对此不做特殊限定。
应当注意,尽管在附图中以特定顺序描述了本公开中方法的各个步骤,但是,这并非要求或者暗示必须按照该特定顺序来执行这些步骤,或是必须执行全部所示的步骤才能实现期望的结果。附加的或备选的,可以省略某些步骤,将多个步骤合并为一个步骤执行,以及/或者将一个步骤分解为多个步骤执行等。
进一步的,本示例实施方式中还提供了一种系统升级后应用启动异常处理装置。
图3示意性示出了本公开的示例性实施方式的系统升级后应用启动异常处理装置的方框图。参考图3,根据本公开的示例性实施方式的系统升级后应用启动异常处理装置3可以包括文件获取模块31、文件转换模块33和文件加载模块35。
具体的,文件获取模块31可以用于在系统升级后,获取目标应用的可执行文件;文件转换模块33可以用于将目标应用的可执行文件转换为二进制文件;文件加载模块35用于响应用户针对目标应用的启动操作,通过虚拟机加载二进制文件。
根据本公开示例性实施方式的系统升级后应用启动异常处理装置,通过在系统升级后主动将应用的可执行文件转换为计算机能够识别的二进制文件,在这种情况下,当应用启动时,可以直接获取转换的二进制文件,避免了相关技术中用户启动应用时读取旧版本文件而导致加载异常的问题,解决了应用启动时出现例如黑屏的问题,另外,用户使用体验的提升,有助于提高系统升级的用户接受度。
根据本公开的示例性实施例,参考图4,系统升级后应用启动异常处理装置4相比于系统升级后应用启动异常处理装置3,还可以包括升级检测模块41。
具体的,升级检测模块41可以用于通过检测升级标志位来确定系统是否升级。
根据本公开的示例性实施例,参考图5,文件获取模块31可以包括优先等级确定单元501和文件获取单元503。
具体的,优先等级确定单元501可以用于确定目标应用的优先处理等级;文件获取单元503可以用于在将优先处理等级比目标应用高的应用的可执行文件转换为二进制文件后,获取目标应用的可执行文件。
通过按优先处理等级对系统各应用进行分批处理,相比于同时处理的方案,缓解了运算压力。
根据本公开的示例性实施例,优先等级确定单元501可以被配置为执行:确定一预设时间段内,目标应用相比于预设时间段的运行时长占比;根据运行时长占比确定目标应用的优先处理等级。
利用运行时间占比这一指标来确定优先处理等级,由此,用户使用频繁的应用可以优先处理,以便及时满足用户使用需求。
根据本公开的示例性实施例,参考图6,系统升级后应用启动异常处理装置6相比于系统升级后应用启动异常处理装置3,还可以包括启动处理模块61。
具体的,启动处理模块61可以被配置为执行:在将目标应用的可执行文件转换为二进制文件之前,如果接收到目标应用的启动指令,则控制目标应用暂停启动,直至完成将目标应用的可执行文件转换为二进制文件为止。
根据本公开的示例性实施例,启动处理模块61还可以被配置为执行:在将目标应用的可执行文件转换为二进制文件之前,如果接收到目标应用的启动指令,则判断当前是否获取到目标应用的可执行文件;如果获取到目标应用的可执行文件,则将目标应用的可执行文件转换为二进制文件,以便通过虚拟机加载所述二进制文件;如果未获取到目标应用的可执行文件,则获取目标应用的可执行文件,并将目标应用的可执行文件转换为二进制文件,以便通过虚拟机加载二进制文件。
根据本公开的示例性实施例,启动处理模块61还可以被配置为执行:在将所述目标应用的可执行文件转换为二进制文件之前,如果接收到所述目标应用的启动指令,则在显示界面上呈现等待提示信息,直至完成将所述目标应用的可执行文件转换为二进制文件为止。
通过启动处理模块61的处理过程,一方面,可以防止在未生成目标应用的二进制文件时读取到旧版本的文件而导致例如黑屏的异常情况;另一方面,可以提前进行目标应用的文件转换过程,以确保能够及时满足用户针对目标应用的使用需求。
由于本发明实施方式的程序运行性能分析装置的各个功能模块与上述方法发明实施方式中相同,因此在此不再赘述。
在本公开的示例性实施例中,还提供了一种计算机可读存储介质,其上存储有能够实现本说明书上述方法的程序产品。在一些可能的实施方式中,本发明的各个方面还可以实现为一种程序产品的形式,其包括程序代码,当所述程序产品在终端设备上运行时,所述程序代码用于使所述终端设备执行本说明书上述“示例性方法”部分中描述的根据本发明各种示例性实施方式的步骤。
根据本发明的实施方式的用于实现上述方法的程序产品可以采用便携式紧凑盘只读存储器(CD-ROM)并包括程序代码,并可以在终端设备,例如个人电脑上运行。然而,本发明的程序产品不限于此,在本文件中,可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
所述程序产品可以采用一个或多个可读介质的任意组合。可读介质可以是可读信号介质或者可读存储介质。可读存储介质例如可以为但不限于电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光盘、便携式紧凑盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。
计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了可读程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。可读信号介质还可以是可读存储介质以外的任何可读介质,该可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。
可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于无线、有线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言的任意组合来编写用于执行本发明操作的程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、C++等,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、作为一个独立的软件包执行、部分在用户计算设备上部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。在涉及远程计算设备的情形中,远程计算设备可以通过任意种类的网络,包括局域网(LAN)或广域网(WAN),连接到用户计算设备,或者,可以连接到外部计算设备(例如利用因特网服务提供商来通过因特网连接)。
在本公开的示例性实施例中,还提供了一种能够实现上述方法的电子设备。
所属技术领域的技术人员能够理解,本发明的各个方面可以实现为系统、方法或程序产品。因此,本发明的各个方面可以具体实现为以下形式,即:完全的硬件实施方式、完全的软件实施方式(包括固件、微代码等),或硬件和软件方面结合的实施方式,这里可以统称为“电路”、“模块”或“系统”。
下面参照图7来描述根据本发明的这种实施方式的电子设备700。图7显示的电子设备700仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图7所示,电子设备700以通用计算设备的形式表现。电子设备700的组件可以包括但不限于:上述至少一个处理单元710、上述至少一个存储单元720、连接不同系统组件(包括存储单元720和处理单元710)的总线730、显示单元740。
其中,所述存储单元存储有程序代码,所述程序代码可以被所述处理单元710执行,使得所述处理单元710执行本说明书上述“示例性方法”部分中描述的根据本发明各种示例性实施方式的步骤。例如,所述处理单元710可以执行如图1中所示的步骤S12:在系统升级后,获取目标应用的可执行文件;步骤S14:将目标应用的可执行文件转换为二进制文件;步骤S16:响应用户针对目标应用的启动操作,通过虚拟机加载二进制文件。
存储单元720可以包括易失性存储单元形式的可读介质,例如随机存取存储单元(RAM)7201和/或高速缓存存储单元7202,还可以进一步包括只读存储单元(ROM)7203。
存储单元720还可以包括具有一组(至少一个)程序模块7205的程序/实用工具7204,这样的程序模块7205包括但不限于:操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。
总线730可以为表示几类总线结构中的一种或多种,包括存储单元总线或者存储单元控制器、外围总线、图形加速端口、处理单元或者使用多种总线结构中的任意总线结构的局域总线。
电子设备700也可以与一个或多个外部设备800(例如键盘、指向设备、蓝牙设备等)通信,还可与一个或者多个使得用户能与该电子设备700交互的设备通信,和/或与使得该电子设备700能与一个或多个其它计算设备进行通信的任何设备(例如路由器、调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口750进行。并且,电子设备700还可以通过网络适配器760与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。如图所示,网络适配器760通过总线730与电子设备700的其它模块通信。应当明白,尽管图中未示出,可以结合电子设备700使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储系统等。
通过以上的实施方式的描述,本领域的技术人员易于理解,这里描述的示例实施方式可以通过软件实现,也可以通过软件结合必要的硬件的方式来实现。因此,根据本公开实施方式的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个非易失性存储介质(可以是CD-ROM,U盘,移动硬盘等)中或网络上,包括若干指令以使得一台计算设备(可以是个人计算机、服务器、终端装置、或者网络设备等)执行根据本公开实施方式的方法。
此外,上述附图仅是根据本发明示例性实施例的方法所包括的处理的示意性说明,而不是限制目的。易于理解,上述附图所示的处理并不表明或限制这些处理的时间顺序。另外,也易于理解,这些处理可以是例如在多个模块中同步或异步执行的。
应当注意,尽管在上文详细描述中提及了用于动作执行的设备的若干模块或者单元,但是这种划分并非强制性的。实际上,根据本公开的实施方式,上文描述的两个或更多模块或者单元的特征和功能可以在一个模块或者单元中具体化。反之,上文描述的一个模块或者单元的特征和功能可以进一步划分为由多个模块或者单元来具体化。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本公开的其他实施例。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限。

Claims (10)

1.一种系统升级后应用启动异常处理方法,其特征在于,包括:
在系统升级后,获取目标应用的可执行文件;
将所述目标应用的可执行文件转换为二进制文件;
响应用户针对所述目标应用的启动操作,通过虚拟机加载所述二进制文件。
2.根据权利要求1所述的系统升级后应用启动异常处理方法,其特征在于,所述系统升级后应用启动异常处理方法还包括:
通过检测升级标志位来确定系统是否升级。
3.根据权利要求1所述的系统升级后应用启动异常处理方法,其特征在于,获取目标应用的可执行文件包括:
确定目标应用的优先处理等级;
在将优先处理等级比所述目标应用高的应用的可执行文件转换为二进制文件后,获取目标应用的可执行文件。
4.根据权利要求3所述的系统升级后应用启动异常处理方法,其特征在于,确定目标应用的优先处理等级包括:
确定一预设时间段内,目标应用相比于所述预设时间段的运行时长占比;
根据所述运行时长占比确定目标应用的优先处理等级。
5.根据权利要求3所述的系统升级后应用启动异常处理方法,其特征在于,所述系统升级后应用启动异常处理方法还包括:
在将所述目标应用的可执行文件转换为二进制文件之前,如果接收到所述目标应用的启动指令,则控制所述目标应用暂停启动,直至完成将所述目标应用的可执行文件转换为二进制文件为止。
6.根据权利要求5所述的系统升级后应用启动异常处理方法,其特征在于,所述系统升级后应用启动异常处理方法还包括:
在将所述目标应用的可执行文件转换为二进制文件之前,如果接收到所述目标应用的启动指令,则判断当前是否获取到所述目标应用的可执行文件;
如果获取到所述目标应用的可执行文件,则将所述目标应用的可执行文件转换为二进制文件,以便通过虚拟机加载所述二进制文件;
如果未获取到所述目标应用的可执行文件,则获取所述目标应用的可执行文件,并将所述目标应用的可执行文件转换为二进制文件,以便通过虚拟机加载所述二进制文件。
7.根据权利要求5或6所述的系统升级后应用启动异常处理方法,其特征在于,所述系统升级后应用启动异常处理方法还包括:
在将所述目标应用的可执行文件转换为二进制文件之前,如果接收到所述目标应用的启动指令,则在显示界面上呈现等待提示信息,直至完成将所述目标应用的可执行文件转换为二进制文件为止。
8.一种系统升级后应用启动异常处理装置,其特征在于,包括:
文件获取模块,用于在系统升级后,获取目标应用的可执行文件;
文件转换模块,用于将所述目标应用的可执行文件转换为二进制文件;
文件加载模块,用于响应用户针对所述目标应用的启动操作,通过虚拟机加载所述二进制文件。
9.一种存储介质,其上存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现权利要求1至7中任一项所述的系统升级后应用启动异常处理方法。
10.一种电子设备,其特征在于,包括:
处理器;以及
存储器,用于存储所述处理器的可执行指令;
其中,所述处理器配置为经由执行所述可执行指令来执行权利要求1至7中任一项所述的系统升级后应用启动异常处理方法。
CN201910522083.3A 2019-06-17 2019-06-17 系统升级后应用启动异常处理方法及装置、介质和设备 Pending CN110333969A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201910522083.3A CN110333969A (zh) 2019-06-17 2019-06-17 系统升级后应用启动异常处理方法及装置、介质和设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201910522083.3A CN110333969A (zh) 2019-06-17 2019-06-17 系统升级后应用启动异常处理方法及装置、介质和设备

Publications (1)

Publication Number Publication Date
CN110333969A true CN110333969A (zh) 2019-10-15

Family

ID=68141990

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201910522083.3A Pending CN110333969A (zh) 2019-06-17 2019-06-17 系统升级后应用启动异常处理方法及装置、介质和设备

Country Status (1)

Country Link
CN (1) CN110333969A (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111427630A (zh) * 2020-03-31 2020-07-17 北京金堤科技有限公司 冷启动优化方法和装置、电子设备和存储介质
CN113572683A (zh) * 2020-04-29 2021-10-29 腾讯科技(深圳)有限公司 数据处理方法、装置、电子设备及存储介质

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20030229890A1 (en) * 2002-06-07 2003-12-11 Michael Lau Method and system for optimizing software upgrades
CN103677870A (zh) * 2012-09-10 2014-03-26 腾讯科技(深圳)有限公司 系统升级方法及采用该方法升级的系统
CN106020865A (zh) * 2016-05-10 2016-10-12 百度在线网络技术(北京)有限公司 一种系统升级方法和装置
CN109857474A (zh) * 2017-11-30 2019-06-07 华为终端有限公司 启动应用程序的方法和装置

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20030229890A1 (en) * 2002-06-07 2003-12-11 Michael Lau Method and system for optimizing software upgrades
CN103677870A (zh) * 2012-09-10 2014-03-26 腾讯科技(深圳)有限公司 系统升级方法及采用该方法升级的系统
CN106020865A (zh) * 2016-05-10 2016-10-12 百度在线网络技术(北京)有限公司 一种系统升级方法和装置
CN109857474A (zh) * 2017-11-30 2019-06-07 华为终端有限公司 启动应用程序的方法和装置

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111427630A (zh) * 2020-03-31 2020-07-17 北京金堤科技有限公司 冷启动优化方法和装置、电子设备和存储介质
CN111427630B (zh) * 2020-03-31 2024-03-22 北京金堤科技有限公司 冷启动优化方法和装置、电子设备和存储介质
CN113572683A (zh) * 2020-04-29 2021-10-29 腾讯科技(深圳)有限公司 数据处理方法、装置、电子设备及存储介质
CN113572683B (zh) * 2020-04-29 2023-07-04 腾讯科技(深圳)有限公司 数据处理方法、装置、电子设备及存储介质

Similar Documents

Publication Publication Date Title
EP3821330B1 (en) Electronic device and method for generating short cut of quick command
EP3010015B1 (en) Electronic device and method for spoken interaction thereof
US10818285B2 (en) Electronic device and speech recognition method therefor
US20200364085A1 (en) Task scheduling based on performance control conditions for multiple processing units
EP3441844B1 (en) Flexible device and operating method therefor
EP3333704A1 (en) Method and apparatus for repairing kernel vulnerability
EP3109762A1 (en) Electronic device having external memory and method for operating the same
CN104978965A (zh) 电子装置及利用电子装置和服务器的语音识别执行方法
US10402222B2 (en) Task migration method and apparatus
US11662976B2 (en) Electronic device and method for sharing voice command thereof
CN109918166A (zh) 小程序处理方法、装置及电子设备
US10489135B2 (en) Electronic device and method for improving installation speed of theme package
US11720905B2 (en) Intelligent merchant onboarding
CN110333969A (zh) 系统升级后应用启动异常处理方法及装置、介质和设备
CN109684573A (zh) 目标图片显示方法及装置、存储介质、电子设备
EP2805233A1 (en) Installation engine and package format for parallelizable, reliable installations
US20180314417A1 (en) Electronic device for outputting graphic indication
CN110515671A (zh) 初始化方法、初始化装置、终端设备及可读存储介质
CN110489106A (zh) 一种项目初始化代码的生成方法、装置、介质和电子设备
CN109800020A (zh) 一种程序开发的代码自动调整方法、装置、设备和介质
CN104137074A (zh) 多环境计算系统中资源使用的优化
EP3157002A1 (en) Electronic device and method for transforming text to speech utilizing super-clustered common acoustic data set for multi-lingual/speaker
US10331433B2 (en) Hybrid operating system for an in-vehicle apparatus
CN111459506A (zh) 深度学习平台集群的部署方法、装置、介质及电子设备
KR20210046426A (ko) 어플리케이션의 최적화 방법 및 이를 지원하는 전자 장치

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
RJ01 Rejection of invention patent application after publication

Application publication date: 20191015

RJ01 Rejection of invention patent application after publication