CN108958911B - 进程的控制方法及装置 - Google Patents
进程的控制方法及装置 Download PDFInfo
- Publication number
- CN108958911B CN108958911B CN201810543075.2A CN201810543075A CN108958911B CN 108958911 B CN108958911 B CN 108958911B CN 201810543075 A CN201810543075 A CN 201810543075A CN 108958911 B CN108958911 B CN 108958911B
- Authority
- CN
- China
- Prior art keywords
- lock
- memory
- target process
- mutual exclusion
- application program
- 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
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/48—Program initiating; Program switching, e.g. by interrupt
- G06F9/4806—Task transfer initiation or dispatching
- G06F9/4843—Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
- G06F9/4881—Scheduling strategies for dispatcher, e.g. round robin, multi-level priority queues
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/52—Program synchronisation; Mutual exclusion, e.g. by means of semaphores
- G06F9/526—Mutual exclusion algorithms
- G06F9/528—Mutual exclusion algorithms by using speculative mechanisms
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
Abstract
本公开是关于一种进程的控制方法及装置,用以提高前台应用程序的运行速度,解决前台应用进程因为无法快速获取互斥锁而造成的卡顿问题。所述方法包括:获取前台应用程序对应的目标进程的目标进程标识;在目标进程获取互斥锁时,根据所述目标进程标识将所述目标进程向所述互斥锁的等待队列的头部调整。本公开技术方案可以提高前台应用程序的运行速度,解决前台应用进程因为无法快速获取互斥锁而造成的卡顿问题。
Description
技术领域
本公开涉及通信技术领域,尤其涉及一种进程的控制方法及装置。
背景技术
相关技术中,在多核多任务***中,为了防止多进程并发访问临界资源造成数据破坏,操作***使用互斥锁来保证同一时刻只有一个进程访问临界资源。其中,多个线程不能同时使用的资源称为临界资源。进程在访问临界资源前需要先获取锁,当锁被其他进程持有时,当前进程就被阻塞,直到持锁进程释放锁。然而,如何控制进程访问临界资源避免前台应用程序卡顿是需要解决的一个技术问题。
发明内容
为克服相关技术中存在的问题,本公开实施例提供一种进程的控制方法及装置,用以提高前台应用程序的运行速度。
根据本公开实施例的第一方面,提供一种进程的控制方法,包括:
获取前台应用程序对应的目标进程的目标进程标识;
在所述目标进程获取互斥锁时,根据所述目标进程标识将所述目标进程向所述互斥锁的等待队列的头部调整。
在一个实施例中,所述根据所述目标进程标识将所述目标进程向所述互斥锁的等待队列的头部调整之前,还可包括:
确定所述互斥锁被除所述目标进程以外的进程所持有。
在一个实施例中,所述确定所述互斥锁被除所述目标进程以外的进程所持有之后,还可包括:
如果检测到持有所述互斥锁的持锁进程被抢占,则提高所述持锁进程的优先级,以使所述持锁进程持有所述互斥锁的时间缩短。
在一个实施例中,所述提高所述持锁进程的优先级之后,还可包括:
提高所述持锁进程的运行速度;
在所述持锁进程完成访问临界资源后,释放所述互斥锁。
在一个实施例中,所述根据所述目标进程标识将所述目标进程向所述互斥锁的等待队列的头部调整之前,还包括:
获取所述目标进程的进程信息中的状态标识;
根据所述状态标识确定所述前台应用程序处于等待状态。
在一个实施例中,所述获取前台应用程序对应的目标进程的目标进程标识之后,还可包括:
从内存池中为所述前台应用程序分配内存。
在一个实施例中,所述方法,还可包括:
当所述内存池的剩余内存低于预设阈值时,唤醒内核线程,所述内核线程用于从***内存中获取内存填充至所述内存池。
根据本公开实施例的第二方面,提供一种进程的控制装置,包括:
第一获取模块,被配置为获取前台应用程序对应的目标进程的目标进程标识;
第一调整模块,被配置为在所述目标进程获取互斥锁时,根据所述目标进程标识将所述目标进程向所述互斥锁的等待队列的头部调整。
在一个实施例中,所述装置,还包括:
第一确定模块,被配置为确定所述互斥锁被除所述目标进程以外的进程所持有。
在一个实施例中,所述装置,还包括:
第二调整模块,被配置为在检测到持有所述互斥锁的持锁进程被抢占时,提高所述持锁进程的优先级,以使所述持锁进程持有所述互斥锁的时间缩短。
在一个实施例中,所述装置,还包括:
第三调整模块,被配置为提高所述持锁进程的运行速度;
释放模块,被配置为在所述持锁进程完成访问临界资源后,释放所述互斥锁。
在一个实施例中,所述装置,还包括:
第二获取模块,被配置为获取所述目标进程的进程信息中的状态标识;
第二确定模块,被配置为根据所述状态标识确定所述前台应用程序处于等待状态。
在一个实施例中,所述装置,还可包括:
分配模块,被配置为从内存池中为所述前台应用程序分配内存。
在一个实施例中,所述装置,还可包括:
唤醒模块,被配置为在所述内存池的剩余内存低于预设阈值时,唤醒内核线程,所述内核线程用于从***内存中获取内存填充至所述内存池。
根据本公开实施例的第三方面,提供一种进程的控制装置,包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行:上述第一方面所述的方法。
根据本公开实施例的第四方面,提供一种计算机可读存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现上述第一方面所述的方法。
本公开的实施例提供的技术方案可以包括以下有益效果:通过在所述目标进程获取互斥锁时将前台应用程序对应的目标进程向互斥锁的等待队列的头部调整,以使目标进程在互斥锁被释放后以优先次序持有所述互斥锁。这样,可以减少前台应用程序获取互斥锁的等待时间,进而可以提高前台应用程序的运行速度,解决前台应用进程因为无法快速获取互斥锁而造成的卡顿问题。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本发明的实施例,并与说明书一起用于解释本发明的原理。
图1是根据一示例性实施例示出的进程的控制方法的流程图。
图2是根据一示例性实施例示出的进程的控制方法的应用场景图。
图3A~图3B是根据另一示例性实施例示出的进程的控制方法的应用场景图。
图4是根据另一示例性实施例示出的进程的控制方法的流程图。
图5是根据一示例性实施例示出的进程的控制装置的框图。
图6是根据另一示例性实施例示出的进程的控制装置的框图。
图7是根据另一示例性实施例示出的进程的控制装置的框图。
图8是根据另一示例性实施例示出的进程的控制装置的框图。
图9是根据另一示例性实施例示出的进程的控制装置的框图。
图10是根据一示例性实施例示出的一种进程的控制装置的框图。
具体实施方式
这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本发明相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本发明的一些方面相一致的装置和方法的例子。
相关技术中,在多核多任务***中,为了防止多进程并发访问临界资源造成数据破坏,操作***使用互斥锁来保证同一时刻只有一个进程访问临界资源,进程在访问临界资源前需要先获取互斥锁,当互斥锁被其他进程持有时,当前进程就被阻塞,直到持锁进程释放锁。
上述的锁机制很好的保护了临界资源,保证了数据的完整性,但是也带来的性能的问题。在手机的操作***中对临界资源的访问是互斥的,进程之间是平等的。当一个前台应用进程访问临界资源的时候,将会和其他进程一样,在互斥锁的等待队列中排队,直到获取互斥锁。然而,前台应用是用户可见,可操作的,长时间阻塞会造成应用卡顿,影响用户体验。
本公开实施例提供一种进程的控制方法及装置,用于解决上述的技术问题,提高前台应用程序的运行速度。
图1是根据一示例性实施例示出的进程的控制方法的流程图。该方法可以应用于终端设备,例如智能手机、平板电脑(PAD)等。如图1所示,该进程的控制方法包括以下步骤S101~S102:
在步骤S101中,获取前台应用程序对应的目标进程的目标进程标识。
在一个实施例中,可以在一个应用程序启动时,或者,在一个应用程序切换为前台应用程序时,获取前台应用程序对应的目标进程的目标进程标识。其中,上述的应用程序启动后为前台应用程序。前台应用程序是用户可视、可操作的应用程序。
在一个示例性实施例中,终端设备可以是智能手机,智能手机搭载的操作***可以是安卓(Android)操作***。在一个应用程序启动时,或者,在一个应用程序切换为前台应用程序时,可以通过Application Framework(应用框架)层获取前台应用程序对应的目标进程的目标进程标识,并将获取的目标进程标识发送给linux内核,linux内核将接收的目标进程标识保存在内核文件中,以供后续使用。
在一个实施例中,可以在操作***启动时,初始化内存池,该内存池供前台应用使用。也就是,本公开实施例提供一个专门供前台应用程序使用的内存池,而后台应用程序仍从***内存中分配内存。
在一个实施例中,可以在应用程序启动时,获取应用程序对应的进程的进程标识,并保存在linux内核文件中。所述进程标识可以用于区分前台进程和后台进程。前台进程是前台应用程序对应的进程,后台进程是后台应用程序对应的进程。也就是,当linux内核文件保存有目标进程标识时,该目标进程标识对应的目标进程即为前台进程。
在一个实施例中,可以在应用程序启动后,即应用程序切换为前台应用程序后,从内存池中为所述前台应用程序分配内存。在一个示例性场景中,如图2所示,当所述内存池23的剩余内存低于预设阈值时,可以唤醒一个内核线程,该内核线程用于从***内存24中获取内存填充至所述内存池23,其中,内存池23供前台应用程序21使用,而后台应用程序22仍从***内存24中分配内存。这样,通过进程标识区分前台应用程序与后台应用程序,可以给前台应用程序提供快速的分配内存通道,前台应用程序分配内存耗时大大减少,并可以达到99%的内存从内存池分配。
在步骤S102中,在所述目标进程获取互斥锁时,根据所述目标进程标识将所述目标进程向所述互斥锁的等待队列的头部调整。
在一个实施例中,当目标进程访问临界资源时,需要先获取互斥锁。当目标进程持有互斥锁时才能访问临界资源。在目标进程获取互斥锁时,可以根据所述目标进程标识将所述目标进程向所述互斥锁的等待队列的头部调整,以使目标进程在互斥锁被释放后以优先次序持有所述互斥锁。在一个示例性实施例中,可以将目标进程置于所述互斥锁的等待队列的头部,这样,一旦互斥锁被释放,目标进程可以以第一次序持有所述互斥锁,然后访问临界资源。
在一个实施例中,步骤S102之前,可以先获取所述目标进程的进程信息中的状态标识,然后根据所述状态标识确定所述前台应用程序是否处于等待状态。当所述前台应用程序处于等待状态时,所述目标进程在等待获取互斥锁,例如,目标进程在所述互斥锁的等待队列中等待获取互斥锁。在一个实施例中,目标进程的进程信息中的预设字段用于保存状态标识,状态标识用于向操作***指示目标进程所处的状态。当所述前台应用程序处于等待状态时,确定目标进程在互斥锁的等待队列中等待获取互斥锁,以访问临界资源。
在一个实施例中,在所述目标进程获取互斥锁时,可以先确定所述互斥锁是否被除所述目标进程以外的进程所持有。当确定所述互斥锁被除所述目标进程以外的进程所持有时,将所述目标进程置于所述互斥锁的等待队列的头部。这样,当持有所述互斥锁的持锁进程完成访问临界资源并释放所述互斥锁后,目标进程可以以第一次序持有所述互斥锁,然后访问临界资源。
在一个实施例中,当目标进程没有位于等待队列的头部时,将目标进程***等待队列的头部。当目标进程位于等待队列的头部时,不调整目标进程的位置。在一个示例性场景中,如图3A所示,等待队列的头部是进程31,尾部是目标进程33,中间是进程32,则将目标进程33***等待队列的头部,得到新的等待队列,具体请参阅图3B。
在一个实施例中,在所述目标进程获取互斥锁时,如果所述互斥锁被除所述目标进程以外的进程所持有,且检测到持有所述互斥锁的持锁进程被抢占,则可以提高所述持锁进程的优先级,以使所述持锁进程持有所述互斥锁的时间缩短。继续上述的示例性实施例,持锁进程被抢占的情况包括:当持锁进程的被分配的时间片用完时,暂时停止运行,或者,CPU因执行优先级比持锁进程的优先级高的进程而暂时停止执行持锁进程,等等。当持锁进程被抢占时,互斥锁没有被释放,只有当持锁进程被CPU继续执行并访问临界资源完毕时才会释放互斥锁。因此,为缩短所述持锁进程持有所述互斥锁的时间,可以提高所述持锁进程的优先级。当提高所述持锁进程的优先级后,持锁进程可以优先得到CPU资源,或者等到更多的CPU资源,进而提高所述持锁进程的运行速度,尽快完成对临界资源的访问,在所述持锁进程完成访问临界资源后,释放所述互斥锁。
继续上述的示例性实施例,在提高所述持锁进程的优先级时,可以提高所述持锁进程的标准优先级。其中,标准优先级也可称之为普通优先级,标准优先级低于实时优先级。当一个进程的优先级为实时优先级时,操作***会主动分配更多的CPU频率和更多的内存来运行这个进程。
在本实施例中,通过在所述目标进程获取互斥锁时将前台应用程序对应的目标进程向互斥锁的等待队列的头部调整,以使目标进程在互斥锁被释放后以优先次序持有所述互斥锁。这样,可以减少前台应用程序获取互斥锁的等待时间,进而可以提高前台应用程序的运行速度,解决前台应用进程因为无法快速获取互斥锁而造成的卡顿问题。
图4是根据另一示例性实施例示出的进程的控制方法的流程图。在图1所示的实施例的基础上,上述的步骤S101之后,还包括以下步骤S401~S404:
在步骤S401中,确定所述互斥锁被除所述目标进程以外的进程所持有。
在步骤S402中,如果检测到持有所述互斥锁的持锁进程被抢占,则提高所述持锁进程的优先级。
在步骤S403中,提高所述持锁进程的运行速度。
在步骤S404中,在所述持锁进程完成访问临界资源后,释放所述互斥锁。
在一个实施例中,在所述目标进程获取互斥锁时,可以先确定所述互斥锁是否被除所述目标进程以外的进程所持有。当确定所述互斥锁被除所述目标进程以外的进程所持有时,检测持有所述互斥锁的持锁进程是否被抢占。当持有所述互斥锁的持锁进程被抢占时,提高所述持锁进程的优先级,以使所述持锁进程持有所述互斥锁的时间缩短。
继续上述的示例性实施例,持锁进程被抢占的情况包括:当持锁进程的被分配的时间片用完时,暂时停止运行,或者,CPU因执行优先级比持锁进程的优先级高的进程而暂时停止执行持锁进程,等等。当持锁进程被抢占时,互斥锁没有被释放,只有当持锁进程被CPU继续执行并访问临界资源完毕时才会释放互斥锁。
在一个实施例中,为缩短所述持锁进程持有所述互斥锁的时间,可以提高所述持锁进程的优先级。当提高所述持锁进程的优先级后,持锁进程可以优先得到CPU资源,或者等到更多的CPU资源。
在一个实施例中,随着提高持锁进程的优先级,提高所述持锁进程的运行速度,以尽快完成对临界资源的访问,并在所述持锁进程完成访问临界资源后,释放所述互斥锁。
继续上述的示例性实施例,在提高所述持锁进程的优先级时,可以提高所述持锁进程的标准优先级。其中,标准优先级也可称之为普通优先级,标准优先级低于实时优先级。当一个进程的优先级为实时优先级时,操作***会主动分配更多的CPU频率和更多的内存来运行这个进程。
在本实施例中,通过提高持锁进程的优先级,可以提高持锁进程的运行速度,缩短持锁进程持锁的时间,进而,可以缩短目标进程的等待时间,提高前台应用程序的运行速度,解决前台应用进程因为无法快速获取互斥锁而造成的卡顿问题。
图5是根据一示例性实施例示出的进程的控制装置的框图。本公开实施例提供的进程的控制装置,包括:
第一获取模块51,被配置为获取前台应用程序对应的目标进程的目标进程标识;
第一调整模块52,被配置为在所述目标进程获取互斥锁时,根据所述目标进程标识将所述目标进程向所述互斥锁的等待队列的头部调整。
图6是根据另一示例性实施例示出的进程的控制装置的框图。本公开实施例中,所述装置,还可包括:
第一确定模块53,被配置为确定所述互斥锁被除所述目标进程以外的进程所持有。
图7是根据另一示例性实施例示出的进程的控制装置的框图。本公开实施例中,所述装置,还可包括:
第二调整模块54,被配置为在检测到持有所述互斥锁的持锁进程被抢占时,提高所述持锁进程的优先级,以使所述持锁进程持有所述互斥锁的时间缩短。
图8是根据另一示例性实施例示出的进程的控制装置的框图。本公开实施例中,所述装置,还可包括:
第三调整模块55,被配置为提高所述持锁进程的运行速度;
释放模块56,被配置为在所述持锁进程完成访问临界资源后,释放所述互斥锁。
图9是根据另一示例性实施例示出的进程的控制装置的框图。本公开实施例中,所述装置,还可包括:
第二获取模块57,被配置为获取所述目标进程的进程信息中的状态标识;
第二确定模块58,被配置为根据所述状态标识确定所述前台应用程序处于等待状态。
在一个实施例中,所述装置,还可包括:
分配模块,被配置为从内存池中为所述前台应用程序分配内存。
在一个实施例中,所述装置,还可包括:
唤醒模块,被配置为在所述内存池的剩余内存低于预设阈值时,唤醒内核线程,所述内核线程用于从***内存中获取内存填充至所述内存池。
关于上述实施例中的装置,其中处理器执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
图10是根据一示例性实施例示出的一种进程的控制装置的框图。例如,装置1000可以是移动电话,计算机,数字广播终端,消息收发设备,游戏控制台,平板设备,医疗设备,健身设备,个人数字助理等。
参照图10,装置1000可以包括以下一个或多个组件:处理组件1002,存储器1004,电源组件1006,多媒体组件1008,音频组件1010,输入/输出(I/O)的接口1012,传感器组件1014,以及通信组件1016。
处理组件1002通常控制装置1000的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理元件1002可以包括一个或多个处理器1020来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件1002可以包括一个或多个模块,便于处理组件1002和其他组件之间的交互。例如,处理部件1002可以包括多媒体模块,以方便多媒体组件1008和处理组件1002之间的交互。
存储器1004被配置为存储各种类型的数据以支持在设备1000的操作。这些数据的示例包括用于在装置1000上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器1004可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM),电可擦除可编程只读存储器(EEPROM),可擦除可编程只读存储器(EPROM),可编程只读存储器(PROM),只读存储器(ROM),磁存储器,快闪存储器,磁盘或光盘。
电力组件1006为装置1000的各种组件提供电力。电力组件1006可以包括电源管理***,一个或多个电源,及其他与为装置1000生成、管理和分配电力相关联的组件。
多媒体组件1008包括在所述装置1000和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件1008包括一个前置摄像头和/或后置摄像头。当设备1000处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜***或具有焦距和光学变焦能力。
音频组件1010被配置为输出和/或输入音频信号。例如,音频组件1010包括一个麦克风(MIC),当装置1000处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器1004或经由通信组件1016发送。在一些实施例中,音频组件1010还包括一个扬声器,用于输出音频信号。
I/O接口1012为处理组件1002和***接口模块之间提供接口,上述***接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件1014包括一个或多个传感器,用于为装置1000提供各个方面的状态评估。例如,传感器组件1014可以检测到设备1000的打开/关闭状态,组件的相对定位,例如所述组件为装置1000的显示器和小键盘,传感器组件1014还可以检测装置1000或装置1000一个组件的位置改变,用户与装置1000接触的存在或不存在,装置1000方位或加速/减速和装置1000的温度变化。传感器组件1014可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件1014还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件1014还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
通信组件1016被配置为便于装置1000和其他设备之间有线或无线方式的通信。装置1000可以接入基于通信标准的无线网络,如WiFi,2G或3G,或它们的组合。在一个示例性实施例中,通信部件1016经由广播信道接收来自外部广播管理***的广播信号或广播相关信息。在一个示例性实施例中,所述通信部件1016还包括近场通信(NFC)模块,以促进短程通信。例如,在NFC模块可基于射频识别(RFID)技术,红外数据协会(IrDA)技术,超宽带(UWB)技术,蓝牙(BT)技术和其他技术来实现。
在示例性实施例中,装置1000可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器1004,上述指令可由装置1000的处理器1020执行以完成上述方法。例如,所述非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
本领域技术人员在考虑说明书及实践这里公开的公开后,将容易想到本公开的其它实施方案。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。
本领域技术人员在考虑说明书及实践这里公开的公开后,将容易想到本公开的其它实施方案。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。
Claims (14)
1.一种进程的控制方法,其特征在于,所述方法包括:
获取前台应用程序对应的目标进程的目标进程标识;所述前台应用程序为启动后的应用程序,且为用户可视、可操作的应用程序;
在所述目标进程获取互斥锁时,根据所述目标进程标识将所述目标进程向所述互斥锁的等待队列的头部调整;
所述获取前台应用程序对应的目标进程的目标进程标识之后,还包括:
从内存池中为所述前台应用程序分配内存,其中,后台应用程序从***内存中分配内存。
2.根据权利要求1所述的方法,其特征在于,所述根据所述目标进程标识将所述目标进程向所述互斥锁的等待队列的头部调整之前,还包括:
确定所述互斥锁被除所述目标进程以外的进程所持有。
3.根据权利要求2所述的方法,其特征在于,所述确定所述互斥锁被除所述目标进程以外的进程所持有之后,还包括:
如果检测到持有所述互斥锁的持锁进程被抢占,则提高所述持锁进程的优先级,以使所述持锁进程持有所述互斥锁的时间缩短。
4.根据权利要求3所述的方法,其特征在于,所述提高所述持锁进程的优先级之后,还包括:
提高所述持锁进程的运行速度;
在所述持锁进程完成访问临界资源后,释放所述互斥锁。
5.根据权利要求1所述的方法,其特征在于,所述根据所述目标进程标识将所述目标进程向所述互斥锁的等待队列的头部调整之前,还包括:
获取所述目标进程的进程信息中的状态标识;
根据所述状态标识确定所述前台应用程序处于等待状态。
6.根据权利要求1所述的方法,其特征在于,所述方法,还包括:
当所述内存池的剩余内存低于预设阈值时,唤醒内核线程,所述内核线程用于从***内存中获取内存填充至所述内存池。
7.一种进程的控制装置,其特征在于,所述装置包括:
第一获取模块,被配置为获取前台应用程序对应的目标进程的目标进程标识;所述前台应用程序为启动后的应用程序,且为用户可视、可操作的应用程序;
第一调整模块,被配置为在所述目标进程获取互斥锁时,根据所述目标进程标识将所述目标进程向所述互斥锁的等待队列的头部调整;
所述装置,还包括:
分配模块,被配置为从内存池中为所述前台应用程序分配内存,其中,后台应用程序从***内存中分配内存。
8.根据权利要求7所述的装置,其特征在于,所述装置,还包括:
第一确定模块,被配置为确定所述互斥锁被除所述目标进程以外的进程所持有。
9.根据权利要求8所述的装置,其特征在于,所述装置,还包括:
第二调整模块,被配置为在检测到持有所述互斥锁的持锁进程被抢占时,提高所述持锁进程的优先级,以使所述持锁进程持有所述互斥锁的时间缩短。
10.根据权利要求9所述的装置,其特征在于,所述装置,还包括:
第三调整模块,被配置为提高所述持锁进程的运行速度;
释放模块,被配置为在所述持锁进程完成访问临界资源后,释放所述互斥锁。
11.根据权利要求7所述的装置,其特征在于,所述装置,还包括:
第二获取模块,被配置为获取所述目标进程的进程信息中的状态标识;
第二确定模块,被配置为根据所述状态标识确定所述前台应用程序处于等待状态。
12.根据权利要求7所述的装置,其特征在于,所述装置,还包括:
唤醒模块,被配置为在所述内存池的剩余内存低于预设阈值时,唤醒内核线程,所述内核线程用于从***内存中获取内存填充至所述内存池。
13.一种进程的控制装置,其特征在于,所述装置包括:
处理器;
用于存储处理器可执行指令的存储器;
其中,所述处理器被配置为执行权利要求1至6任一项所述的方法。
14.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现权利要求1至6任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810543075.2A CN108958911B (zh) | 2018-05-30 | 2018-05-30 | 进程的控制方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810543075.2A CN108958911B (zh) | 2018-05-30 | 2018-05-30 | 进程的控制方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN108958911A CN108958911A (zh) | 2018-12-07 |
CN108958911B true CN108958911B (zh) | 2022-02-08 |
Family
ID=64492279
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810543075.2A Active CN108958911B (zh) | 2018-05-30 | 2018-05-30 | 进程的控制方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN108958911B (zh) |
Families Citing this family (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110532197B (zh) * | 2019-08-30 | 2022-03-01 | Oppo(重庆)智能科技有限公司 | 内存回收方法及装置、电子设备、存储介质 |
CN110543384B (zh) * | 2019-09-05 | 2022-05-17 | Oppo广东移动通信有限公司 | 内存的回写方法、装置、终端及存储介质 |
CN112162845B (zh) * | 2020-10-30 | 2023-10-13 | 北京北信源软件股份有限公司 | 一种业务进程同步的方法及装置 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1527206A (zh) * | 2003-03-03 | 2004-09-08 | 华为技术有限公司 | 一种内存池管理的方法 |
CN101055533A (zh) * | 2007-05-28 | 2007-10-17 | 中兴通讯股份有限公司 | 一种多线程处理器动态内存管理***及方法 |
US8429657B2 (en) * | 2008-04-28 | 2013-04-23 | Oracle International Corporation | Global avoidance of hang states via priority inheritance in multi-node computing system |
CN103473126A (zh) * | 2013-09-09 | 2013-12-25 | 北京思特奇信息技术股份有限公司 | 一种多级别任务处理方法 |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1276361C (zh) * | 2003-12-29 | 2006-09-20 | 北京中视联数字***有限公司 | 一种嵌入式***内存管理的方法 |
CN102819497B (zh) * | 2012-05-31 | 2015-09-30 | 华为技术有限公司 | 一种内存分配方法、装置及*** |
US9274832B2 (en) * | 2013-02-07 | 2016-03-01 | Htc Corporation | Method and electronic device for thread scheduling |
US9619012B2 (en) * | 2014-05-30 | 2017-04-11 | Apple Inc. | Power level control using power assertion requests |
-
2018
- 2018-05-30 CN CN201810543075.2A patent/CN108958911B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1527206A (zh) * | 2003-03-03 | 2004-09-08 | 华为技术有限公司 | 一种内存池管理的方法 |
CN101055533A (zh) * | 2007-05-28 | 2007-10-17 | 中兴通讯股份有限公司 | 一种多线程处理器动态内存管理***及方法 |
US8429657B2 (en) * | 2008-04-28 | 2013-04-23 | Oracle International Corporation | Global avoidance of hang states via priority inheritance in multi-node computing system |
CN103473126A (zh) * | 2013-09-09 | 2013-12-25 | 北京思特奇信息技术股份有限公司 | 一种多级别任务处理方法 |
Non-Patent Citations (3)
Title |
---|
A priority mutex with bounded waiting for interactive consumer electronics systems;Hojung Choi;《2018 IEEE International Conference on Consumer Electronics (ICCE)》;20180329;全文 * |
刘德岩.基于Linux的嵌入式实时***ERLinux.《中国优秀博硕士学位论文全文数据库(硕士)信息科技辑》.2005,第2005年卷(第3期), * |
基于Linux的嵌入式实时***ERLinux;刘德岩;《中国优秀博硕士学位论文全文数据库(硕士)信息科技辑》;20050715;第2005年卷(第3期);I138-123 * |
Also Published As
Publication number | Publication date |
---|---|
CN108958911A (zh) | 2018-12-07 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN105955765B (zh) | 应用预加载方法及装置 | |
US9588805B2 (en) | Method and terminal device for controlling background application | |
US20190361581A1 (en) | Method, terminal and computer-readable storage medium device for displaying interface of application program | |
CN109254849B (zh) | 应用程序的运行方法及装置 | |
US9886264B2 (en) | Method and device for upgrading firmware | |
EP3188066A1 (en) | A method and an apparatus for managing an application | |
CN105338409B (zh) | 一种网络视频预加载方法及装置 | |
CN106020943B (zh) | 应用程序双开启方法及装置 | |
CN107193653B (zh) | 带宽资源分配方法、装置及存储介质 | |
EP3015983B1 (en) | Method and device for optimizing memory | |
CN107992257B (zh) | 分屏方法及装置 | |
CN108958911B (zh) | 进程的控制方法及装置 | |
US11700578B2 (en) | Downlink control signaling detection method and apparatus, and storage medium | |
CN115576645B (zh) | 一种虚拟处理器调度方法、装置、存储介质及电子设备 | |
US9678868B2 (en) | Method and device for optimizing memory | |
US20170293494A1 (en) | Method and device for starting application interface | |
CN113703937A (zh) | 动画切换方法及装置、存储介质 | |
CN109062625B (zh) | 应用程序加载的方法、装置及可读存储介质 | |
CN110968523A (zh) | 内存碎片整理的方法和装置 | |
CN107371222B (zh) | 虚拟卡禁用方法及装置 | |
CN105094500B (zh) | 一种图标摆放方法及装置 | |
CN106502740B (zh) | 应用安装方法和装置 | |
EP3200075A1 (en) | Method and device for calling process | |
CN107220008B (zh) | 存储空间预留方法及装置 | |
CN106535147B (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 |