CN114968551B - 一种进程管理的方法、装置、电子设备及存储介质 - Google Patents

一种进程管理的方法、装置、电子设备及存储介质 Download PDF

Info

Publication number
CN114968551B
CN114968551B CN202210238640.0A CN202210238640A CN114968551B CN 114968551 B CN114968551 B CN 114968551B CN 202210238640 A CN202210238640 A CN 202210238640A CN 114968551 B CN114968551 B CN 114968551B
Authority
CN
China
Prior art keywords
state
busy
sub
control
running state
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.)
Active
Application number
CN202210238640.0A
Other languages
English (en)
Other versions
CN114968551A (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.)
China Mobile Communications Group Co Ltd
China Mobile Internet Co Ltd
Original Assignee
China Mobile Communications Group Co Ltd
China Mobile Internet Co 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 China Mobile Communications Group Co Ltd, China Mobile Internet Co Ltd filed Critical China Mobile Communications Group Co Ltd
Priority to CN202210238640.0A priority Critical patent/CN114968551B/zh
Publication of CN114968551A publication Critical patent/CN114968551A/zh
Application granted granted Critical
Publication of CN114968551B publication Critical patent/CN114968551B/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/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5011Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals
    • G06F9/5016Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals the resource being the memory
    • 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/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5027Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
    • G06F9/5055Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals considering software capabilities, i.e. software resources associated or available to the machine
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2209/00Indexing scheme relating to G06F9/00
    • G06F2209/50Indexing scheme relating to G06F9/50
    • G06F2209/509Offload
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Debugging And Monitoring (AREA)

Abstract

本申请公开了一种进程管理的方法、装置、电子设备及存储介质,属于计算机技术领域,用以提高应用程序资源的利用率,避免了应用程序资源的浪费,能够解决应用程序内存资源消耗多过的问题。所述方法包括:获取应用程序所对应的子进程的控件状态和所述应用程序的程序运行状态,其中,所述控件状态包括控件运行状态或控件未运行状态,所述程序运行状态包括前台运行状态、后台运行状态或锁屏运行状态;根据所述控件状态和/或所述程序运行状态,确定所述子进程的忙闲状态,其中,所述忙闲状态包括空闲状态或繁忙状态;根据所述忙闲状态,对所述子进程进行相应的管理操作。

Description

一种进程管理的方法、装置、电子设备及存储介质
技术领域
本申请属于计算机技术领域,具体涉及一种进程管理的方法、装置、电子设备及存储介质。
背景技术
进程是程序关于数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础,通常情况下,一个应用默认只有一个进程,每个进程拥有独立的内存空间和资源,分配给每个进程的内存是有限度的,如果应用程序的内存占用过大,超过了分配的内存上限则会出现应用崩溃无法使用的后果,为此,引入了多进程,将应用程序中占用大量内存的控件放入另一个进程。
但是,多进程方案中仍然存在应用程序内存资源消耗多过的问题。
发明内容
本申请实施例提供一种进程管理的方法、装置、电子设备及存储介质,能够提高应用程序资源的利用率,避免了应用程序资源的浪费,能够解决应用程序内存资源消耗多过的问题。
第一方面,本申请实施例提供了一种进程管理的方法,该方法包括:获取应用程序所对应的子进程的控件状态和所述应用程序的程序运行状态,其中,所述控件状态包括控件运行状态或控件未运行状态,所述程序运行状态包括后台、后台运行状态或锁屏运行状态;根据所述控件状态和/或所述程序运行状态,确定所述子进程的忙闲状态,其中,所述忙闲状态包括空闲状态或繁忙状态;根据所述忙闲状态,对所述子进程进行相应的管理操作。
第二方面,本申请实施例提供了一种进程管理的装置,该装置包括:获取模块,用于获取应用程序所对应的子进程的控件状态和所述应用程序的程序运行状态,其中,所述控件状态包括控件运行状态或控件未运行状态,所述程序运行状态包括前台运行状态、后台运行状态或锁屏运行状态;确定模块,根据所述控件状态和/或所述程序运行状态,确定所述子进程的忙闲状态,其中,所述忙闲状态包括空闲状态或繁忙状态;管理模块,根据所述忙闲状态,对所述子进程进行相应的管理操作。
第三方面,本申请实施例提供了一种电子设备,该电子设备包括处理器、存储器及存储在所述存储器上并可在所述处理器上运行的程序或指令,所述程序或指令被所述处理器执行时实现如第一方面所述的方法的步骤。
第四方面,本申请实施例提供了一种可读存储介质,所述可读存储介质上存储程序或指令,所述程序或指令被处理器执行时实现如第一方面所述的方法的步骤。
在本申请实施例中,通过获取应用程序所对应的子进程的控件状态和所述应用程序的程序运行状态,其中,所述控件状态包括控件运行状态或控件未运行状态,所述程序运行状态包括前台运行状态、后台运行状态或锁屏运行状态;根据所述控件状态和/或所述程序运行状态,确定所述子进程的忙闲状态,其中,所述忙闲状态包括空闲状态或繁忙状态;根据所述忙闲状态,对所述子进程进行相应的管理操作;这使得能够在子进程空闲状态的情况下,释放掉多余的资源,从而提高应用程序资源的利用率,避免了应用程序资源的浪费,能够解决应用程序内存资源消耗多过的问题。
附图说明
图1是本申请实施例提供的一种进程管理的方法的流程示意图;
图2是本申请实施例提供的另一种进程管理的方法的流程示意图;
图3是本申请的一个实施例提供的一种进程管理的装置的结构示意图;
图4是本申请的实施例提供的电子设备的结构示意图;
图5是本申请的实施例提供的另一种电子设备的结构示意图。
具体实施方式
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
下面结合附图,通过具体的实施例及其应用场景对本申请实施例提供的一种进程管理的方法、装置、电子设备及存储介质进行详细地说明。
图1示出本发明的一个实施例提供的一种进程管理的方法,该方法可以由电子设备执行,该电子设备可以包括:服务器和/或终端设备。换言之,该方法可以由安装在电子设备的软件或硬件来执行,该方法包括如下步骤:
步骤102:获取应用程序所对应的子进程的控件状态和所述应用程序的程序运行状态。
在本步骤中,可以获取应用程序所对应的子进程的控件状态和应用程序的程序运行状态,其中,控件状态包括控件运行状态或控件未运行状态,程序运行状态包括前台运行状态、后台运行状态或锁屏运行状态。
具体的,本发明在运行应用程序时创建多个进程,按照实际业务需要划分子进程,使用多进程策略,将图片、视频、浏览器、文件预览器等不是后台频繁运行并且占用内存较大的控件分配到子进程中运行,将控件和主进程隔离开来,各自拥有独立的内存空间。当子进程中未运行控件时,子进程的控件状态即为控件未运行状态,子进程中有控件运行时,则子进程的控件状态为控件运行状态。
步骤104:根据所述控件状态和/或所述程序运行状态,确定所述子进程的忙闲状态。
在本步骤中,可以根据控件状态和/或程序运行状态,确定子进程的忙闲状态,其中,子进程的忙闲状态包括空闲状态或繁忙状态。
步骤106:根据所述忙闲状态,对所述子进程进行相应的管理操作。
在本步骤中,可以根据子进程的忙闲状态,对子进程进行相应的管理操作。具体的,管理操作可以包括保持该子进程或关闭该子进程。
此外,本实施例可以通过轮询的方式获取子进程的忙闲状态,即设置一个时间间隔,每隔一个时间间隔获取一次子进程的忙闲状态,并根据获取的子进程的忙闲状态,对子进程进行相应的管理操作。
由此可见,本实施例通过获取应用程序所对应的子进程的控件状态和应用程序的程序运行状态,根据控件状态和/或程序运行状态,确定子进程的忙闲状态,并根据忙闲状态,对子进程进行相应的管理操作,实现了通过锁屏状态、前后台运行状态、控件状态来判断子进程是处于繁忙状态还是空闲状态,提高了判断子进程的忙闲状态的准确性,从而能够依此准确的对子进程进行管理,进而提高了应用程序资源的利用率,避免了应用程序资源的浪费,解决了应用程序内存资源消耗多过的问题。
在一种实现方式中,所述根据所述控件状态和/或所述程序运行状态,确定所述子进程的忙闲状态,包括下述任一项:
若所述控件状态为控件未运行状态,则确定所述忙闲状态为空闲状态;
若所述控件状态为控件运行状态,则确定所述忙闲状态为繁忙状态;
若所述程序运行状态为前台运行状态,则确定所述忙闲状态为繁忙状态;
若所述控件状态为控件未运行状态,且所述程序运行状态为后台运行状态或锁屏运行状态,则确定所述忙闲状态为空闲状态。
具体的,在一种可能的方式中,子进程忙闲状态的判定取决于子进程中是否用控件正在运行,若子进程中没有控件正在运行,即子进程的控件状态为控件未运行状态,则可以确定子进程的忙闲状态为空闲状态;若子进程中正在运行控件,即子进程中的控件状态为控件运行状态,则可以确定子进程的忙闲状态为繁忙状态。
此外,在另一种可能的方式中,若应用程序的程序运行状态为前台运行状态,则说明分配到子进程中的控件可能随时会被使用,此时需要保持子进程存活,因此,若应用程序的程序运行状态为前台运行状态,则可以确定子进程的忙闲状态为繁忙状态。
此外,若子进程中没有控件正在运行,即子进程的控件状态为控件未运行状态,并且应用程序的程序运行状态为后台运行状态或者锁屏运行状态,则可以确定子进程的忙闲状态为空闲状态。
本发明实施例提供的进程管理的方法,通过上述方式确定子进程的忙闲状态,使得子进程的忙闲状态和控件状态和程序运行状态相关联,提高了判断子进程的忙闲状态的准确性,从而能够依次准确的对子进程进行管理。
在一种实现方式中,所述根据所述忙闲状态,对所述子进程进行相应的管理操作时,可以若所述忙闲状态为繁忙状态,则保持所述子进程;若所述忙闲状态为空闲状态且所述子进程处于存活状态,则关闭所述子进程。
具体的,若子进程的忙闲状态为繁忙状态,则说明用户随时可能会使用控件,因此,需要保持该子进程,以方便用户的使用。
此外,若子进程的忙闲状态为空闲状态,则空闲状态的子进程会占用内存,并且控件运行结束所申请的资源并不能保证完全释放掉,造成资源的浪费,此时则可以关闭该子进程,以使得所占资源得以释放,节省了应用程序空闲时的资源占用,并避免了控件停止后内存仍占用问题。
此外,在一种实现方式中,关闭所述子进程时可以包括如下步骤:
所述应用程序的主进程监测所述忙闲状态;
若监测到所述忙闲状态为空闲状态且所述子进程处于存活状态,则向所述子进程发送通知消息,其中所述通知消息用于通知所述子进程关闭自身进程。
具体的,应用程序的主进程监测子进程的忙闲状态,若主进程监测到子进程的忙闲状态为空闲状态,则向子进程发送通知消息,在子进程接收到主进程发送的通知消息后,调用进程关闭函数关闭子进程。例如,主进程监测到子进程的忙闲状态为空闲状态,则向子进程发送通知消息,在子进程接收到主进程发送的通知消息后调用系统提供的进程关闭(KillProcess)函数杀死自身进程。
这样,应用程序的主进程监测到忙闲状态为空闲状态且子进程处于存活状态,则向子进程发送通知消息,其中通知消息用于通知子进程关闭自身进程,能够在监测到子进程的忙闲状态为空闲状态且子进程为存活状态的情况下关闭该子进程,提高了应用程序资源的利用率,避免了应用程序空闲状态下的资源浪费,能够解决应用程序内存资源消耗多过的问题。
可选的,下面结合图2,对本申请的一个实施例进行说明,在该实施例中包括如下步骤:
步骤202:获取应用程序所对应的子进程的控件状态和所述应用程序的程序运行状态。
其中,控件状态包括控件运行状态或控件未运行状态,程序运行状态包括前台运行状态、后台运行状态或锁屏运行状态。
具体的,本发明在运行应用程序时,使用多进程策略,将图片、视频、浏览器、文件预览器等不是后台频繁运行并且占用内存较大的控件分配到子进程中运行,将控件和主进程隔离开来,各自拥有独立的内存空间,当子进程中为运行控件时,子进程的控件状态即为控件未运行状态,子进程中有控件运行时,则子进程的控件状态为控件运行状态。
步骤204:根据所述控件状态和/或所述程序运行状态,确定所述子进程的忙闲状态。
具体的,子进程的忙闲状态包括空闲状态或繁忙状态,若控件状态为控件未运行状态,则确定忙闲状态为空闲状态;若控件状态为控件运行状态,则确定忙闲状态为繁忙状态;若程序运行状态为前台运行状态,则确定忙闲状态为繁忙状态;若控件状态为控件未运行状态,且程序运行状态为后台运行状态或锁屏运行状态,则确定忙闲状态为空闲状态。
步骤206:若所述忙闲状态为繁忙状态,则保持所述子进程;若所述忙闲状态为空闲状态且所述子进程处于存活状态,则关闭所述子进程。
具体的,若子进程的忙闲状态为繁忙状态,则说明子进程中有控件正在运行和/或应用程序在前台运行,说明用户随时可能会使用控件,因此,需要保持该子进程。
此外,若子进程的忙闲状态为空闲状态,说明子进程中没有控件正在运行,或应用程序在后台运行或者锁屏运行,而子进程中的资源会占用内存,因此此时可以关闭该子进程,以减少资源的内存占用。
可选的,应用程序的主进程可以监测所述忙闲状态,若监测到所述忙闲状态为空闲状态且所述子进程处于存活状态,则向所述子进程发送通知消息,其中所述通知消息用于通知所述子进程调用进程关闭函数关闭自身进程。
由此可见,本实施例通过获取应用程序所对应的子进程的控件状态和所述应用程序的程序运行状态;根据所述控件状态和/或所述程序运行状态,确定所述子进程的忙闲状态;若所述忙闲状态为繁忙状态,则保持所述子进程;若所述忙闲状态为空闲状态且所述子进程处于存活状态,则关闭所述子进程,实现了通过锁屏状态、前后台运行状态、控件状态来判断子进程是处于繁忙状态还是空闲状态,提高了判断子进程的忙闲状态的准确性,从而能够依此准确的对子进程进行管理,进而提高了应用程序资源的利用率,避免了应用程序资源的浪费,解决了应用程序内存资源消耗多过的问题。
需要说明的是,本申请实施例提供的进程管理的方法,执行主体可以为进程管理的装置,或者该进程管理的装置中的用于执行进程管理的方法的控制模块。本申请实施例中以进程管理的装置执行进程管理的装置方法为例,说明本申请实施例提供的进程管理的装置。
图3是根据本发明实施例的装置名称的结构示意图。如图3所示,装置名称300包括:获取模块310、确定模块320、管理模块330。
获取模块310,用于获取应用程序所对应的子进程的控件状态和所述应用程序的程序运行状态,其中,所述控件状态包括控件运行状态或控件未运行状态,所述程序运行状态包括前台运行状态、后台运行状态或锁屏运行状态;确定模块320,根据所述控件状态和/或所述程序运行状态,确定所述子进程的忙闲状态,其中,所述忙闲状态包括空闲状态或繁忙状态;管理模块330,根据所述忙闲状态,对所述子进程进行相应的管理操作。
在一种实现方式中,确定模块320,用于执行下述任一项:
若所述控件状态为所述控件未运行状态,则确定所述忙闲状态为空闲状态;
若所述控件状态为控件运行状态,则确定所述忙闲状态为繁忙状态;
若所述程序运行状态为前台运行状态,则确定所述忙闲状态为繁忙状态;
若所述控件状态为控件未运行状态,且所述程序运行状态为后台运行状态或锁屏运行状态,则确定所述忙闲状态为空闲状态。
在一种实现方式中,管理模块330,用于若所述忙闲状态为繁忙状态,则保持所述子进程;若所述忙闲状态为空闲状态且所述子进程处于存活状态,则关闭所述子进程。
在一种实现方式中,管理模块330,用于所述应用程序的主进程监测所述忙闲状态;若监测到所述忙闲状态为空闲状态且所述子进程处于存活状态,则向所述子进程发送通知消息,其中所述通知消息用于通知所述子进程关闭自身进程。
本申请实施例中的进程管理的装置可以是装置,也可以是终端中的部件、集成电路、或芯片。该装置可以是移动电子设备,也可以为非移动电子设备。示例性的,移动电子设备可以为手机、平板电脑、笔记本电脑、掌上电脑、车载电子设备、可穿戴设备、超级移动个人计算机(ultra-mobile personal computer,UMPC)、上网本或者个人数字助理(personaldigital assistant,PDA)等,非移动电子设备可以为服务器、网络附属存储器(NetworkAttached Storage,NAS)、个人计算机(personal computer,PC)、电视机(television,TV)、柜员机或者自助机等,本申请实施例不作具体限定。
本申请实施例中的进程管理的装置可以为具有操作系统的装置。该操作系统可以为安卓(Android)操作系统,可以为ios操作系统,还可以为其他可能的操作系统,本申请实施例不作具体限定。
本申请实施例提供的进程管理的装置能够实现图1至图2的方法实施例中实现的各个过程,为避免重复,这里不再赘述。
可选的,如图4所示,本申请实施例还提供一种电子设备400,包括处理器401,存储器402,存储在存储器402上并可在所述处理器401上运行的程序或指令,该程序或指令被处理器401执行时实现上述进程管理的方法实施例的各个过程,且能达到相同的技术效果,为避免重复,这里不再赘述。
需要说明的是,本申请实施例中的电子设备包括上述所述的移动电子设备和非移动电子设备。
图5为实现本申请实施例的一种电子设备的硬件结构示意图。
该电子设备500包括但不限于:射频单元501、网络模块502、音频输出单元503、输入单元504、传感器505、显示单元506、用户输入单元507、接口单元508、存储器509、以及处理器510等部件。
本领域技术人员可以理解,电子设备500还可以包括给各个部件供电的电源(比如电池),电源可以通过电源管理系统与处理器510逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。图中示出的电子设备结构并不构成对电子设备的限定,电子设备可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置,在此不再赘述。
其中,处理器510,用于获取应用程序所对应的子进程的控件状态和所述应用程序的程序运行状态,其中,所述控件状态包括控件运行状态或控件未运行状态,所述程序运行状态包括前台运行状态、后台运行状态或锁屏运行状态;根据所述控件状态和/或所述程序运行状态,确定所述子进程的忙闲状态,其中,所述忙闲状态包括空闲状态或繁忙状态;根据所述忙闲状态,对所述子进程进行相应的管理操作。
在一种实现方式中,处理器510,用于下述任一项:
若所述控件状态为控件未运行状态,则确定所述忙闲状态为空闲状态;
若所述控件状态为控件运行状态,则确定所述忙闲状态为繁忙状态;
若所述程序运行状态为前台运行状态,则确定所述忙闲状态为繁忙状态;
若所述控件状态为控件未运行状态,且所述程序运行状态为后台运行状态或锁屏运行状态,则确定所述忙闲状态为空闲状态。
在一种实现方式中,处理器510,用于若所述忙闲状态为繁忙状态,则保持所述子进程;若所述忙闲状态为空闲状态且所述子进程处于存活状态,则关闭所述子进程。
在一种实现方式中,处理器510,用于所述应用程序的主进程监测所述忙闲状态;若监测到所述忙闲状态为空闲状态且所述子进程处于存活状态,则向所述子进程发送通知消息,其中所述通知消息用于通知所述子进程关闭自身进程。
本实施例可以实现上述进程管理的方法实施例的各个过程,且能达到相同的技术效果,为避免重复,这里不再赘述。应理解的是,本申请实施例中,输入单元504可以包括图形处理器(Graphics Processing Unit,GPU)5041和麦克风5042,图形处理器5041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。显示单元506可包括显示面板5061,可以采用液晶显示器、有机发光二极管等形式来配置显示面板5061。用户输入单元507包括触控面板5071以及其他输入设备5072。触控面板5071,也称为触摸屏。触控面板5071可包括触摸检测装置和触摸控制器两个部分。其他输入设备5072可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆,在此不再赘述。存储器509可用于存储软件程序以及各种数据,包括但不限于应用程序和操作系统。处理器510可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器510中。
本申请实施例还提供一种可读存储介质,所述可读存储介质上存储有程序或指令,该程序或指令被处理器执行时实现上述进程管理的方法实施例的各个过程,且能达到相同的技术效果,为避免重复,这里不再赘述。
其中,所述处理器为上述实施例中所述的电子设备中的处理器。所述可读存储介质,包括计算机可读存储介质,如计算机只读存储器(Read-Only Memory,ROM)、随机存取存储器(Random Access Memory,RAM)、磁碟或者光盘等。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。此外,需要指出的是,本申请实施方式中的方法和装置的范围不限按示出或讨论的顺序来执行功能,还可包括根据所涉及的功能按基本同时的方式或按相反的顺序来执行功能,例如,可以按不同于所描述的次序来执行所描述的方法,并且还可以添加、省去、或组合各种步骤。另外,参照某些示例所描述的特征可在其他示例中被组合。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本申请各个实施例所述的方法。
上面结合附图对本申请的实施例进行了描述,但是本申请并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本申请的启示下,在不脱离本申请宗旨和权利要求所保护的范围情况下,还可做出很多形式,均属于本申请的保护之内。

Claims (4)

1.一种进程管理的方法,其特征在于,包括:
获取应用程序所对应的子进程的控件状态和所述应用程序的程序运行状态,其中,所述控件状态包括控件运行状态或控件未运行状态,所述程序运行状态包括前台运行状态、后台运行状态或锁屏运行状态;
根据所述控件状态和/或所述程序运行状态,确定所述子进程的忙闲状态,其中,所述忙闲状态包括空闲状态或繁忙状态;
根据所述忙闲状态,对所述子进程进行相应的管理操作;
所述方法还包括:
将后台运行频率低于频率阈值且占用内存高于内存阈值的控件分配到子进程中运行;
所述根据所述控件状态和/或所述程序运行状态,确定所述子进程的忙闲状态,包括下述任一项:
若所述控件状态为控件未运行状态,则确定所述忙闲状态为空闲状态;
若所述控件状态为控件运行状态,则确定所述忙闲状态为繁忙状态;
若所述程序运行状态为前台运行状态,则确定所述忙闲状态为繁忙状态;
若所述控件状态为控件未运行状态,且所述程序运行状态为后台运行状态或锁屏运行状态,则确定所述忙闲状态为空闲状态;
所述根据所述忙闲状态,对所述子进程进行相应的管理操作,包括:
若所述忙闲状态为繁忙状态,则保持所述子进程;
若所述忙闲状态为空闲状态且所述子进程处于存活状态,则关闭所述子进程;
所述关闭所述子进程,包括:
所述应用程序的主进程监测所述忙闲状态;
若监测到所述忙闲状态为空闲状态且所述子进程处于存活状态,则向所述子进程发送通知消息,其中所述通知消息用于通知所述子进程关闭自身进程;
所述方法,还包括:
将所述控件与所述主进程隔离开。
2.一种进程管理的装置,其特征在于,包括:
获取模块,用于获取应用程序所对应的子进程的控件状态和所述应用程序的程序运行状态,其中,所述控件状态包括控件运行状态或控件未运行状态,所述程序运行状态包括前台运行状态、后台运行状态或锁屏运行状态;
确定模块,根据所述控件状态和/或所述程序运行状态,确定所述子进程的忙闲状态,其中,所述忙闲状态包括空闲状态或繁忙状态;
管理模块,根据所述忙闲状态,对所述子进程进行相应的管理操作;
分配模块,用于将后台运行频率低于频率阈值且占用内存高于内存阈值的控件分配到子进程中运行;
所述确定模块,用于下述任一项:
若所述控件状态为控件未运行状态,则确定所述忙闲状态为空闲状态;
若所述控件状态为控件运行状态,则确定所述忙闲状态为繁忙状态;
若所述程序运行状态为前台运行状态,则确定所述忙闲状态为繁忙状态;
若所述控件状态为控件未运行状态,且所述程序运行状态为后台运行状态或锁屏运行状态,则确定所述忙闲状态为空闲状态;
所述管理模块,用于:
若所述忙闲状态为繁忙状态,则保持所述子进程;
若所述忙闲状态为空闲状态且所述子进程处于存活状态,则关闭所述子进程;
所述应用程序的主进程监测所述忙闲状态;
若监测到所述忙闲状态为空闲状态且所述子进程处于存活状态,则向所述子进程发送通知消息,其中所述通知消息用于通知所述子进程关闭自身进程;
其中,所述控件与所述主进程隔离开。
3.一种电子设备,其特征在于,包括处理器,存储器及存储在所述存储器上并可在所述处理器上运行的程序或指令,所述程序或指令被所述处理器执行时实现如权利要求1所述的进程管理的方法的步骤。
4.一种可读存储介质,其特征在于,所述可读存储介质上存储程序或指令,所述程序或指令被处理器执行时实现如权利要求1所述的进程管理的方法的步骤。
CN202210238640.0A 2022-03-10 2022-03-10 一种进程管理的方法、装置、电子设备及存储介质 Active CN114968551B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202210238640.0A CN114968551B (zh) 2022-03-10 2022-03-10 一种进程管理的方法、装置、电子设备及存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202210238640.0A CN114968551B (zh) 2022-03-10 2022-03-10 一种进程管理的方法、装置、电子设备及存储介质

Publications (2)

Publication Number Publication Date
CN114968551A CN114968551A (zh) 2022-08-30
CN114968551B true CN114968551B (zh) 2023-09-19

Family

ID=82975532

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202210238640.0A Active CN114968551B (zh) 2022-03-10 2022-03-10 一种进程管理的方法、装置、电子设备及存储介质

Country Status (1)

Country Link
CN (1) CN114968551B (zh)

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2017166617A1 (zh) * 2016-03-31 2017-10-05 乐视控股(北京)有限公司 一种终端控制方法、装置和电子设备
CN107479954A (zh) * 2017-07-31 2017-12-15 广东欧珀移动通信有限公司 进程管理方法、装置、存储介质及电子设备
CN107491346A (zh) * 2016-06-12 2017-12-19 阿里巴巴集团控股有限公司 一种应用的任务处理方法、装置及系统
CN109358955A (zh) * 2018-09-27 2019-02-19 联想(北京)有限公司 进程管理方法和装置
CN109815007A (zh) * 2018-12-15 2019-05-28 平安科技(深圳)有限公司 基于云监控的线程控制方法、装置、电子设备及存储介质
CN110333916A (zh) * 2019-06-18 2019-10-15 平安银行股份有限公司 请求消息处理方法、装置、计算机系统及可读存储介质
CN111538541A (zh) * 2019-12-06 2020-08-14 杭州当虹科技股份有限公司 一种让Android App长期稳定后台运行的方法
CN113448582A (zh) * 2021-08-27 2021-09-28 统信软件技术有限公司 一种窗口显示方法、计算设备及存储介质

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080295114A1 (en) * 2007-05-07 2008-11-27 Pramod Vasant Argade Method and apparatus for execution control of computer programs
US10552179B2 (en) * 2014-05-30 2020-02-04 Apple Inc. Resource management with dynamic resource policies
CN107807847B (zh) * 2016-09-09 2022-04-29 华为技术有限公司 应用进程的管理方法和终端设备

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2017166617A1 (zh) * 2016-03-31 2017-10-05 乐视控股(北京)有限公司 一种终端控制方法、装置和电子设备
CN107491346A (zh) * 2016-06-12 2017-12-19 阿里巴巴集团控股有限公司 一种应用的任务处理方法、装置及系统
CN107479954A (zh) * 2017-07-31 2017-12-15 广东欧珀移动通信有限公司 进程管理方法、装置、存储介质及电子设备
CN109358955A (zh) * 2018-09-27 2019-02-19 联想(北京)有限公司 进程管理方法和装置
CN109815007A (zh) * 2018-12-15 2019-05-28 平安科技(深圳)有限公司 基于云监控的线程控制方法、装置、电子设备及存储介质
CN110333916A (zh) * 2019-06-18 2019-10-15 平安银行股份有限公司 请求消息处理方法、装置、计算机系统及可读存储介质
CN111538541A (zh) * 2019-12-06 2020-08-14 杭州当虹科技股份有限公司 一种让Android App长期稳定后台运行的方法
CN113448582A (zh) * 2021-08-27 2021-09-28 统信软件技术有限公司 一种窗口显示方法、计算设备及存储介质

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
张元亮.《Android开发应用实战详解》.中国铁道出版社,2011,第33-39页. *
熊斌.《iOS开发从入门到精通》.北京希望电子出版社,2013,第102-108页. *

Also Published As

Publication number Publication date
CN114968551A (zh) 2022-08-30

Similar Documents

Publication Publication Date Title
US11586451B2 (en) Resource management with dynamic resource policies
US11513874B2 (en) Memory management methods and systems
US10425349B2 (en) Idle worker-process page-out
US9760413B2 (en) Power efficient brokered communication supporting notification blocking
US8799474B2 (en) Apparatus and method to allocate limited resources
KR20100007907A (ko) 웹 어플리케이션으로서 어플리케이션을 국부적 또는 원격적으로 론치할 지 여부를 결정하는 장치
US11662803B2 (en) Control method, apparatus, and electronic device
CN114327087A (zh) 输入事件处理方法、装置、电子设备和存储介质
CN114968551B (zh) 一种进程管理的方法、装置、电子设备及存储介质
CN110673958B (zh) 调频方法、调频装置、存储介质与电子设备
CN114995914A (zh) 图片数据的处理方法、装置、计算机设备及存储介质
CN113037871A (zh) 会议通话的恢复方法、装置、系统、电子设备和可读存储介质
CN115113992A (zh) 进程控制方法、装置、计算机设备和存储介质
CN113162982B (zh) 埋点信息上报方法、装置和电子设备
CN102385529B (zh) 多cpu领域移动电子装置与其操作方法
CN116820747A (zh) 资源管控方法及其装置、电子设备和可读存储介质
CN117311967A (zh) 内存处理方法、装置及电子设备
CN116662392A (zh) 日志处理方法、装置、电子设备及介质
CN117112250A (zh) 数据处理方法、装置、计算机设备及计算机可读存储介质
CN117149391A (zh) 线程管理方法、装置及电子设备
CN114791831A (zh) 进程管控方法、装置、存储介质及电子设备
CN114885023A (zh) 一种资源调度方法、装置及平台设备
US9348732B2 (en) Microstackshots
CN117544584A (zh) 基于双cpu架构的控制方法、装置、交换机及介质
CN117971250A (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