CN113495787A - 资源分配方法、装置、存储介质及电子设备 - Google Patents

资源分配方法、装置、存储介质及电子设备 Download PDF

Info

Publication number
CN113495787A
CN113495787A CN202010261311.9A CN202010261311A CN113495787A CN 113495787 A CN113495787 A CN 113495787A CN 202010261311 A CN202010261311 A CN 202010261311A CN 113495787 A CN113495787 A CN 113495787A
Authority
CN
China
Prior art keywords
thread
scheduled
processor resources
rule
target
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
CN202010261311.9A
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 CN202010261311.9A priority Critical patent/CN113495787A/zh
Publication of CN113495787A publication Critical patent/CN113495787A/zh
Pending legal-status Critical Current

Links

Images

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/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/5038Allocation 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 the execution order of a plurality of tasks, e.g. taking priority or time dependency constraints into consideration
    • 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/505Allocation 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 the load
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2209/00Indexing scheme relating to G06F9/00
    • G06F2209/50Indexing scheme relating to G06F9/50
    • G06F2209/5018Thread allocation

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

资源分配方法、装置、存储介质及电子设备
技术领域
本申请涉及电子设备技术领域,具体涉及一种资源分配方法、装置、存储介质及电子设备。
背景技术
随着智能手机技术的不断提升,现在用户对智能手机的需求已经不局限于对通话短信等基本功能,他们对于手机运行速度的要求也是日益提高。现在智能手机大多使用安卓***,而在安卓***中,处于***架构底层的linux内核无法清楚明晰地知晓用户使用时的场景,导致对于资源的分配无法做到与使用场景适配。当等待执行的线程较多时,会出现因为一些线程得不到足够的资源而导致电子设备出现卡顿的情况。
发明内容
本申请实施例提供一种资源分配方法、装置、存储介质及电子设备,能够减少电子设备出现卡顿的现象。
第一方面,本申请实施例提供一种资源分配方法,包括:
当接收到加速启动提示信息时,确定所述加速启动提示信息指示的目标线程,并将所述目标线程标记为预设类型的线程;
当需要对待调度线程进行分配处理器资源时,判断所述待调度线程是否为预设类型的线程;
当所述待调度线程为所述预设类型的线程时,按照第一规则为所述待调度线程分配处理器资源;
当所述待调度线程不为所述预设类型的线程时,按照第二规则为所述待调度线程分配处理器资源,其中,基于所述第一规则为线程分配处理器资源的速度或数量,大于基于所述第二规则为线程分配器处理资源的速度或数量。
第二方面,本申请实施例还提供一种资源分配装置,包括:
线程标记模块,用于当接收到加速启动提示信息时,确定所述加速启动提示信息指示的目标线程,并将所述目标线程标记为预设类型的线程;
线程判断模块,用于当需要对待调度线程进行分配处理器资源时,判断所述待调度线程是否为预设类型的线程;
资源分配模块,用于当所述待调度线程为所述预设类型的线程时,按照第一规则为所述待调度线程分配处理器资源;
以及,当所述待调度线程不为所述预设类型的线程时,按照第二规则为所述待调度线程分配处理器资源,其中,基于所述第一规则为线程分配处理器资源的速度或数量,大于基于所述第二规则为线程分配器处理资源的速度或数量。
第三方面,本申请实施例还提供一种存储介质,其上存储有计算机程序,当所述计算机程序在计算机上运行时,使得所述计算机执行如本申请任一实施例提供的资源分配方法。
第四方面,本申请实施例还提供一种电子设备,包括处理器和存储器,所述存储器有计算机程序,所述处理器通过调用所述计算机程序,用于执行如本申请任一实施例提供的资源分配方法。
本申请实施例提供的技术方案,在接收到加速启动提示信息时,确定该加速启动提示信息指示的目标线程,将该目标线程标记为预设类型的线程。当需要对待调度线程进行分配处理器资源时,判断该待调度线程是否为预设类型的线程,如果是,则按照第一规则为其分配处理器资源,如果不是,则按照第二规则为其分配处理器资源,其中,基于第一规则为线程分配处理器资源的速度或数量,大于基于第二规则为线程分配器处理资源的速度或数量。通过这种方式,根据加速启动提示信息,将一些核心线程标记为预设类型的线程,进而将这些线程与其他的非核心线程区别开。并且,相对于非核心线程,在加速时间段内,为核心线程更多更快地分配处理器资源,以使这些线程能够更高效率地执行任务,以减少电子设备出现卡顿的现象。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本申请实施例提供的资源分配方法的第一种流程示意图。
图2为本申请实施例提供的资源分配方法的第二种流程示意图。
图3为本申请实施例提供的资源分配装置的结构示意图。
图4为本申请实施例提供的电子设备的第一种结构示意图。
图5为本申请实施例提供的电子设备的第二种结构示意图。
具体实施方式
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述。显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域技术人员在没有付出创造性劳动前提下所获得的所有其他实施例,都属于本申请的保护范围。
在本文中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本申请的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其它实施例互斥的独立的或备选的实施例。本领域技术人员显式地和隐式地理解的是,本文所描述的实施例可以与其它实施例相结合。
本申请实施例提供一种资源分配方法,该资源分配方法的执行主体可以是本申请实施例提供的资源分配装置,或者集成了该资源分配装置的电子设备,其中该资源分配装置可以采用硬件或者软件的方式实现。其中,电子设备可以是智能手机、平板电脑、掌上电脑、笔记本电脑、或者台式电脑等设备。
请参阅图1,图1为本申请实施例提供的资源分配方法的第一种流程示意图。本申请实施例提供的资源分配方法的具体流程可以如下:
在101中,当接收到加速启动提示信息时,确定所述加速启动提示信息指示的目标线程,并将所述目标线程标记为预设类型的线程。
本申请实施例中,电子设备的操作***可以是基于linux内核的***,例如,安卓操作***等。电子设备中安装的应用程序在运行时,***会为其创建一个进程,并为该进程分配资源。
线程是进程的一条执行路径,是程序执行时的最小单位,也是CPU调度和分派的基本单位。一个进程可以有多个线程,但至少有一个线程。本申请实施例中,进程有任务需要执行时,会创建一个新的线程来执行该任务。
对于不同优先级的线程,会按照不同的线程调度规则进行线程调度。例如,CFS(complete fair schedule,完全公平调度)调度规则等。本实施例中,将采用CFS调度规则进行调度的线程称为CFS线程,并对CFS调度器的调度规则进行优化,以提高预设事件的相关线程的执行效率。
如果电子设备的处理器是多核心处理器,则每一个处理器核心可以当作一个独立的处理单元。比如,如果电子设备为八核处理器,则每一个核心为一个独立的处理单元。每个处理单元有各自对应的任务队列,该任务队列中包含分配给该处理单元的任务,每一个任务由对应的线程去执行。
电子设备中可能有一个或者多个程序在同时运行,每个程序至少有一个对应的进程,而一个进程又有至少一个线程在执行任务。因此,电子设备会有多个线程需要执行,需要为这些线程的执行分配CPU资源。CFS调度器的主调度策略会安装对应的调度机制为线程分配处理单元,并选择最优的进程抢占处理器资源。线程被分配了处理单元后,如果线程进入就绪状态,就会被添加至分配的处理单元的任务队列中,等待被执行。
其中,线程的生命周期可以分为5种状态:新建状态(New):使用new关键字和Thread类或其子类建立一个线程对象后,该线程对象就处于新建状态。它保持这个状态直到程序start()这个线程。就绪状态(Runnable):当线程对象调用了start()方法之后,该线程就进入就绪状态。就绪状态的线程会被添加至就绪队列中,要等待线程调度器的调度。运行状态(Running):如果就绪状态的线程获取CPU资源,就可以执行run()方法,此时线程便处于运行状态,处于运行状态的线程可以变为阻塞状态、就绪状态和死亡状态。阻塞状态(Blocked):如果一个线程执行了sleep(睡眠)、suspend(挂起)等方法,失去所占用资源之后,该线程就从运行状态进入阻塞状态。在睡眠时间已到或获得资源后可以重新进入就绪状态。死亡状态(Dead):一个运行状态的线程完成任务或者其他终止条件发生时,该线程就切换到终止状态。
其中,CFS调度器默认的调度规则如下:按照负载均衡原则为线程分配处理单元,在分配处理单元后,按照线程的优先级为线程分配CPU使用时间。例如,有两个优先级相同的线程在一个CPU上运行,那么每一个线程都会分配到50%的CPU运行时间,即实现公平调度。而当线程的优先级不同时,就会按照线程的权重的比例分配CPU运行时间。其中,权重代表着线程的优先级,权重越大,则优先级越高,分配的CPU运行时间的比例也越大。一般情况下,通过nice值来表示线程的权重,nice值就是一个具体的数字,其取值一般在一个预设的范围之内。数值越小代表优先级越大,同时也意味着权重值越大。
如果CFS调度器始终按照这种规则对CFS线程进行调度,导致对设备资源的分配无法做到与使用场景适配。例如,安卓手机在应用启动(此处以冷启动为例)时,linux内核会创建若干个与此应用的启动过程有关的线程,这些线程在内核中遵从内核线程调度器的指挥,它们和其他线程公平竞争资源,按照相关优先度和负载来决定资源分配。也就是说,内核对启动相关的线程与其他的后台进程一视同仁,并没有为这些与启动过程相关的线程分配更多的资源,整体调度和调频策略也没有采取其他措施,在应用启动负载大的情况下会导致应用启动缓慢,影响用户使用。
其中,应用冷启动是指:当启动应用时,后台没有该应用的进程,***需要重新创建一个新的进程分配给该应用,应用的这种启动方式就是冷启动。
在一些实施例中,当检测到执行预设事件时,确定执行所述预设事件所创建的目标线程,并基于所述目标线程生成加速启动提示信息。
例如,预设事件包括但不限于如下事件:手机冷开机过程、手机热开机过程、应用程序安装过程、触控响应过程、支付过程,以及应用程序启动过程等,其中,应用程序启动过程包括应用热启动过程、应用温启动过程、应用冷启动过程。
在本申请实施例中,可以将电子设备执行一些事件时的相关线程标记为核心线程,对于这些核心线程,对CFS调度器的原始调度规则进行优化,使得CFS调度器能够更快更多地为这些核心线程分配资源,这里的资源包括但不限于CPU资源(即处理器资源)。例如,通过对电子设备执行的事件的监控,来确定将哪些线程标记为核心线程。比如,为了能够加快应用程序的冷启动过程,则在检测到应用程序冷启动时,确定执行应用程序冷启动所创建的线程,将这些线程标记为核心线程。其中,由于***是否会发生卡顿,直接影响着用户体验。可以执行预设事件所创建的目标线程记为ux(user experience,用户体验)线程。
其中,在一些实施例中,可以通过为目标线程添加预设标签的方式将所述目标线程标记为预设类型的线程。例如,为线程添加ux标签,以将线程标记为ux线程。
在一些实施例中,本申请实施例中,***架构的应用框架(framework)层在检测到预设事件时,确定目标线程,并向内核(kernel)层发送加速启动的提示信息,内核层在接收到该提示信息后,将对应的目标线程标记为ux线程。
在执行了这一操作之后,对于CFS调度器来说,全部的CFS线程中就存在了至少两种线程,ux线程和非ux线程,其中,ux线程的重要程度高于非ux线程的重要程度,内核在进行资源分配时会优先为ux线程分配,其资源也会向ux线程倾斜。
在102中,当需要对待调度线程进行分配处理器资源时,判断所述待调度线程是否为预设类型的线程。
在103中,当所述待调度线程为所述预设类型的线程时,按照第一规则为所述待调度线程分配处理器资源。
在104中,当所述待调度线程不为所述预设类型的线程时,按照第二规则为所述待调度线程分配处理器资源,其中,基于所述第一规则为线程分配处理器资源的速度或数量,大于基于所述第二规则为线程分配器处理资源的速度或数量。
本申请实施例中,针对ux线程和非ux线程,采用两种不同的规则来进行处理器资源分配。对于ux线程,按照第一规则分配,对于非ux线程,按照第二规则分配,基于第一规则为线程分配处理器资源的速度或数量,大于基于第二规则为线程分配器处理资源的速度或数量,也就是说,第一规则相当于第二规则,能够更快更多地为线程分配资源。
其中,当根据CFS调度器的主调度策略判定需要为待调度线程分配处理单元,需要对待调度线程进行迁核,或者需要提升待调度线程当前的处理单元的工作频率时,都可以判定需要对待调度线程进行分配处理器资源。其中,迁核是指将线程由当前所在核心迁移至另一核心,以八核CPU为例,其中,八核包括四个大核和四个小核,其中,四个大核为一组,四个小核为一组,在进行迁核时,可以是组内迁核,也可以是不同组之间迁核。
例如,当需要为ux线程分配处理器时,可以优先选择负载小或者大核进行分配。或者,当ux线程需要迁核时,优先选择大核进行迁移。而对于非ux线程,则可以按照CFS调度器默认的负载均衡规则进行资源分配。例如,按照第二规则为所述待调度线程分配处理器资源,可以包括:按照预设的线程调度规则为所述待调度线程分配处理器资源。
具体实施时,本申请不受所描述的各个步骤的执行顺序的限制,在不产生冲突的情况下,某些步骤还可以采用其它顺序进行或者同时进行。
在一些实施例中,所述分配处理器资源为变更处理单元;所述按照第一规则为所述待调度线程分配处理器资源,包括:从候选处理单元中确定出计算能力最大的候选处理单元,作为目标处理单元;将所述待调度线程从当前所在的处理单元迁移至所述目标处理单元执行。
该实施例中,CFS调度器在检测到需要变更某一线程的处理单元时,例如,当检测到某一线程所在的处理单元当前的计算能力不足以执行该线程时,或者,当检测某一线程所在的处理单元负载过高时,或者,当某一线程被唤醒后需要进行迁核处理时,可以判定该线程需要变更处理单元,即俗称的迁核。此时,需要从其他处理单元中,选择一个性能更高或计算能力更好的处理单元,将该线程由当前所在处理单元迁移至新选择的处理单元。将该线程作为待调度线程,先判断该线程是否为ux线程,例如,判断该线程是否具有ux标签,如果该线程具有ux标签,则在从当前所在处理单元之外的其他处理单元中确定出候选处理单元之后,从候选处理单元中选择出性能最高或计算能力最好的候选处理单元,作为目标处理单元,将该线程由当前所在处理单元迁移至新选择的处理单元,使得该ux线程能够得到更多的处理器资源,进而可以快速执行,以加快应用冷启动的速度。如果该线程不具有ux标签,则CFS调度器按照默认的负载均衡规则从当前所在处理单元之外的其他处理单元中选择目标处理单元,并进行迁核处理。
其中,Linux使用task_struct结构体描述和记录线程,每个线程都有唯一属于自己的task_struct结构体。task_struct中记录了线程的标识符、状态、优先级、内存指针、上下文数据等等信息,每一个task_struct中都有一个sched_entity结构,进程的虚拟运行时间(CFS调度器记录的线程虚拟运行时间,按照一定规则根据实际运行时间转换得到)和权重都保存在这个结构中。内核可以在task_struct数据中添加ux标签,以将该线程标记为ux线程。
在一些实施例中,所述分配处理器资源为增大处理单元的工作频率;所述按照第一规则为所述待调度线程分配处理器资源,包括:获取所述待调度线程对应的频率调整值;根据所述频率调整值,增大所述待调度线程当前所在的处理单元的工作频率。
该实施例中,CFS调度器为每一个ux线程设置对应的频率调整值(boost值),其中,ux线程可以具有相同的频率调整值,也可以根据ux线程的优先级的不同,设置不同的boost值。CFS调度器在检测到需要增大某一线程所在的处理单元的工作频率,即俗称的提频时,将该线程作为待调度线程,先判断该线程是否为ux线程,如果是ux线程,则获取该ux线程对应的频率调整值;根据频率调整值,增大该ux线程当前所在的处理单元的工作频率。如果该线程不是ux线程,则CFS调度器按照默认的负载均衡规则对该线程当前所在的处理单元进行提频。
在一些实施例中,所述分配处理器资源为分配处理单元,所述按照第一规则为所述待调度线程分配处理器资源,包括:从候选处理单元中确定出计算能力最大的候选处理单元,作为目标处理单元;将所述待调度线程分配至所述目标处理单元进行执行。
该实施例中,当CFS调度器需要为一个就绪状态的线程分配处理单元时,将该线程作为待调度线程,先判断该线程是否为ux线程,如果是ux线程,则将全部处理单元作为候选处理单元,从候选处理单元中确定出计算能力最大的候选处理单元,作为目标处理单元,将该ux分配至目标处理单元执行。如果该线程不是ux线程,则CFS调度器按照默认的负载均衡规则为该线程分配处理单元。
由上可知,本申请实施例提供的资源分配方法,在接收到加速启动提示信息时,确定该加速启动提示信息指示的目标线程,将该目标线程标记为预设类型的线程。当需要对待调度线程进行分配处理器资源时,判断该待调度线程是否为预设类型的线程,如果是,则按照第一规则为其分配处理器资源,如果不是,则按照第二规则为其分配处理器资源,其中,基于第一规则为线程分配处理器资源的速度或数量,大于基于第二规则为线程分配器处理资源的速度或数量。通过这种方式,根据加速启动提示信息,将一些核心线程标记为预设类型的线程,进而将这些线程与其他的非核心线程区别开。并且,相对于非核心线程,在加速时间段内,为核心线程更多更快地分配处理器资源,以使这些线程能够更高效率地执行任务,以减少电子设备出现卡顿的现象。
根据前面实施例所描述的方法,以下将举例作进一步详细说明。
请参阅图2,图2为本发明实施例提供的资源分配方法的第二流程示意图。
该实施例中,电子设备的***架构至少包括应用框架层和内核层,其中,应用框架层执行201和202,内核层执行203至207。所述方法包括:
在201中,当检测到执行预设事件时,确定执行所述预设事件所创建的目标线程,并基于所述目标线程生成加速启动提示信息。
在202中,当检测到执行预设事件执行完毕时,基于所述目标线程生成加速终止提示信息。
其中,预设事件包括但不限于如下事件:手机冷开机过程、手机热开机过程、应用程序安装过程、触控响应过程、支付过程,以及应用程序启动过程等,其中,应用程序启动过程包括应用热启动过程、应用温启动过程、应用冷启动过程。
当电子设备在执行这些事件时,确定电子设备执行预设事件所创建的目标线程,并基于所述目标线程生成加速启动提示信息,并将该加速启动提示信息发送至内核层。当检测到电子设备执行完毕该预设事件时,应用框架层生成加速终止提示信息发送至内核层。
在203中,当接收到加速启动提示信息时,确定所述加速启动提示信息指示的目标线程,并将所述目标线程标记为预设类型的线程。
内核层在接收到该提示信息后,将对应的目标线程标记为ux线程。
在204中,当需要对待调度线程进行分配处理器资源时,判断所述待调度线程是否为预设类型的线程。
当所述待调度线程为所述预设类型的线程时,执行205;当所述待调度线程不为所述预设类型的线程时,执行206。
在205中,按照第一规则为所述待调度线程分配处理器资源。
在206中,按照第二规则为所述待调度线程分配处理器资源,其中,基于所述第一规则为线程分配处理器资源的速度或数量,大于基于所述第二规则为线程分配器处理资源的速度或数量。
本申请实施例中,针对ux线程和非ux线程,采用两种不同的规则来进行处理器资源分配。对于ux线程,按照第一规则分配,对于非ux线程,按照第二规则分配,基于第一规则为线程分配处理器资源的速度或数量,大于基于第二规则为线程分配器处理资源的速度或数量,也就是说,第一规则相当于第二规则,能够更快更多地为线程分配资源。
当根据CFS调度器的主调度策略判定需要为待调度线程分配处理单元,需要对待调度线程进行迁核,或者需要提升待调度线程当前的处理单元的工作频率时,都可以判定需要对待调度线程进行分配处理器资源。在这些情况下,可以分别按照对应的第一规则进行资源分配。具体分配请参照上述实施例,在此不再赘述。
在207中,当接收到加速终止提示信息时,确定所述加速终止提示信息指示的目标线程,并删除所述目标线程的预设标签。
当预设事件执行完毕,则应用框架层可以向内核层发送加速终止提示信息,内核层接收到该提示信息后,则取消对应的目标线程的预设类型的线程的标记,例如,删除ux标签,以使该线程又称为普通线程。
其中,CFS调度器进行周期性调度,例如其调度周期记为一个tick,则CFS调度器每间隔一个tick进行一次调度。每间隔一个tick,CFS调度器会根据线程的执行情况和各处理单元的负载进行调度管理。
当一个ux线程在执行过程中变更为非ux线程后,在下一个调度周期,CFS调度器恢复至默认的负载均衡规则对该线程进行调度。
由上可知,本发明实施例提出的资源分配方法,应用框架层在检测到特定事件时,基于该特定事件的线程向内核发送加速通知,内核将这些特定事件的相关线程标记为预设类型的线程,以将这些线程与其他的非核心线程区别开。相对于非核心线程,在加速时间段内,为核心线程更多更快地分配处理器资源,以使这些线程能够更高效率地执行任务,以减少电子设备出现卡顿的现象。
在一实施例中还提供一种资源分配装置。请参阅图3,图3为本申请实施例提供的资源分配装置300的结构示意图。其中该资源分配装置300应用于电子设备,该资源分配装置300包括线程标记模块301、线程判断模块302以及资源分配模块303,如下:
线程标记模块301,用于当接收到加速启动提示信息时,确定所述加速启动提示信息指示的目标线程,并将所述目标线程标记为预设类型的线程;
线程判断模块302,用于当需要对待调度线程进行分配处理器资源时,判断所述待调度线程是否为预设类型的线程;
资源分配模块303,用于当所述待调度线程为所述预设类型的线程时,按照第一规则为所述待调度线程分配处理器资源;
以及,当所述待调度线程不为所述预设类型的线程时,按照第二规则为所述待调度线程分配处理器资源,其中,基于所述第一规则为线程分配处理器资源的速度或数量,大于基于所述第二规则为线程分配器处理资源的速度或数量。
在一些实施例中,所述分配处理器资源为变更处理单元;资源分配模块303还用于:从候选处理单元中确定出计算能力最大的候选处理单元,作为目标处理单元;将所述待调度线程从当前所在的处理单元迁移至所述目标处理单元执行。
在一些实施例中,所述分配处理器资源为增大处理单元的工作频率;资源分配模块303还用于:获取所述待调度线程对应的频率调整值;根据所述频率调整值,增大所述待调度线程当前所在的处理单元的工作频率。
在一些实施例中,所述分配处理器资源为分配处理单元;资源分配模块303还用于:从候选处理单元中确定出计算能力最大的候选处理单元,作为目标处理单元;将所述待调度线程分配至所述目标处理单元进行执行。
在一些实施例中,该资源分配装置300还包括:
信息生成模块,用于当检测到执行预设事件时,确定执行所述预设事件所创建的目标线程,并基于所述目标线程生成加速启动提示信息。
在一些实施例中,所述装置应用于电子设备,所述预设事件为所述电子设备启动、应用程序启动或者应用程序安装。
在一些实施例中,线程标记模块301还用于:为所述目标线程添加预设标签,以将所述目标线程标记为预设类型的线程;
以及,当接收到加速终止提示信息时,确定所述加速终止提示信息指示的目标线程,并删除所述目标线程的预设标签。
在一些实施例中,资源分配模块303还用于:
按照预设的线程调度规则为所述待调度线程分配处理器资源。
具体实施时,以上各个模块可以作为独立的实体来实现,也可以进行任意组合,作为同一或若干个实体来实现,以上各个模块的具体实施可参见前面的方法实施例,在此不再赘述。
应当说明的是,本申请实施例提供的资源分配装置与上文实施例中的资源分配方法属于同一构思,在资源分配装置上可以运行资源分配方法实施例中提供的任一方法,其具体实现过程详见资源分配方法实施例,此处不再赘述。
由上可知,本申请实施例提出的资源分配装置,包括线程标记模块301、线程判断模块302以及,在接收到加速启动提示信息时,线程标记模块301确定该加速启动提示信息指示的目标线程,将该目标线程标记为预设类型的线程。当需要对待调度线程进行分配处理器资源时,线程判断模块302判断该待调度线程是否为预设类型的线程,如果是,则资源分配模块303按照第一规则为其分配处理器资源,如果不是,则资源分配模块303按照第二规则为其分配处理器资源,其中,基于第一规则为线程分配处理器资源的速度或数量,大于基于第二规则为线程分配器处理资源的速度或数量。通过这种方式,根据加速启动提示信息,将一些核心线程标记为预设类型的线程,进而将这些线程与其他的非核心线程区别开。并且,相对于非核心线程,在加速时间段内,为核心线程更多更快地分配处理器资源,以使这些线程能够更高效率地执行任务,以减少电子设备出现卡顿的现象。
本申请实施例还提供一种电子设备。所述电子设备可以是智能手机、平板电脑等设备。请参阅图4,图4为本申请实施例提供的电子设备的第一种结构示意图。电子设备400包括处理器401和存储器402。其中,处理器401与存储器402电性连接。
处理器401是电子设备400的控制中心,利用各种接口和线路连接整个电子设备的各个部分,通过运行或调用存储在存储器402内的计算机程序,以及调用存储在存储器402内的数据,执行电子设备的各种功能和处理数据,从而对电子设备进行整体监控。
存储器402可用于存储计算机程序和数据。存储器402存储的计算机程序中包含有可在处理器中执行的指令。计算机程序可以组成各种功能模块。处理器401通过调用存储在存储器402的计算机程序,从而执行各种功能应用以及数据处理。
在本实施例中,电子设备400中的处理器401会按照如下的步骤,将一个或一个以上的计算机程序的进程对应的指令加载到存储器402中,并由处理器401来运行存储在存储器402中的计算机程序,从而实现各种功能:
当接收到加速启动提示信息时,确定所述加速启动提示信息指示的目标线程,并将所述目标线程标记为预设类型的线程;
当需要对待调度线程进行分配处理器资源时,判断所述待调度线程是否为预设类型的线程;
当所述待调度线程为所述预设类型的线程时,按照第一规则为所述待调度线程分配处理器资源;
当所述待调度线程不为所述预设类型的线程时,按照第二规则为所述待调度线程分配处理器资源,其中,基于所述第一规则为线程分配处理器资源的速度或数量,大于基于所述第二规则为线程分配器处理资源的速度或数量。
在一些实施例中,请参阅图5,图5为本申请实施例提供的电子设备的第二种结构示意图。电子设备400还包括:射频电路403、显示屏404、控制电路405、输入单元406、音频电路407、传感器408以及电源409。其中,处理器401分别与射频电路403、显示屏404、控制电路405、输入单元406、音频电路407、传感器408以及电源409电性连接。
射频电路403用于收发射频信号,以通过无线通信与网络设备或其他电子设备进行通信。
显示屏404可用于显示由用户输入的信息或提供给用户的信息以及电子设备的各种图形用户接口,这些图形用户接口可以由图像、文本、图标、视频和其任意组合来构成。
控制电路405与显示屏404电性连接,用于控制显示屏404显示信息。
输入单元406可用于接收输入的数字、字符信息或用户特征信息(例如指纹),以及产生与用户设置以及功能控制有关的键盘、鼠标、操作杆、光学或者轨迹球信号输入。其中,输入单元406可以包括指纹识别模组。
音频电路407可通过扬声器、传声器提供用户与电子设备之间的音频接口。其中,音频电路407包括麦克风。所述麦克风与所述处理器401电性连接。所述麦克风用于接收用户输入的语音信息。
传感器408用于采集外部环境信息。传感器408可以包括环境亮度传感器、加速度传感器、陀螺仪等传感器中的一种或多种。
电源409用于给电子设备400的各个部件供电。在一些实施例中,电源409可以通过电源管理***与处理器401逻辑相连,从而通过电源管理***实现管理充电、放电、以及功耗管理等功能。
虽然图中未示出,电子设备400还可以包括摄像头、蓝牙模块等,在此不再赘述。
在本实施例中,电子设备400中的处理器401会按照如下的步骤,将一个或一个以上的计算机程序的进程对应的指令加载到存储器402中,并由处理器401来运行存储在存储器402中的计算机程序,从而实现各种功能:
当接收到加速启动提示信息时,确定所述加速启动提示信息指示的目标线程,并将所述目标线程标记为预设类型的线程;
当需要对待调度线程进行分配处理器资源时,判断所述待调度线程是否为预设类型的线程;
当所述待调度线程为所述预设类型的线程时,按照第一规则为所述待调度线程分配处理器资源;
当所述待调度线程不为所述预设类型的线程时,按照第二规则为所述待调度线程分配处理器资源,其中,基于所述第一规则为线程分配处理器资源的速度或数量,大于基于所述第二规则为线程分配器处理资源的速度或数量。
在一些实施例中,所述分配处理器资源为变更处理单元;所述按照第一规则为所述待调度线程分配处理器资源时,处理器401执行:
从候选处理单元中确定出计算能力最大的候选处理单元,作为目标处理单元;将所述待调度线程从当前所在的处理单元迁移至所述目标处理单元执行。
在一些实施例中,所述分配处理器资源为增大处理单元的工作频率;所述按照第一规则为所述待调度线程分配处理器资源时,处理器401执行:
获取所述待调度线程对应的频率调整值;根据所述频率调整值,增大所述待调度线程当前所在的处理单元的工作频率。
在一些实施例中,所述分配处理器资源为分配处理单元;按照第一规则为所述待调度线程分配处理器资源时,处理器401执行:
从候选处理单元中确定出计算能力最大的候选处理单元,作为目标处理单元;将所述待调度线程分配至所述目标处理单元进行执行。
在一些实施例中,当接收到加速启动提示信息时,确定所述加速启动提示信息指示的目标线程,并将所述目标线程标记为预设类型的线程之前,处理器401还执行:
当检测到执行预设事件时,确定执行所述预设事件所创建的目标线程,并基于所述目标线程生成加速启动提示信息。
在一些实施例中,所述预设事件为所述电子设备启动、应用程序启动或者应用程序安装。
在一些实施例中,处理器401还执行:为所述目标线程添加预设标签,以将所述目标线程标记为预设类型的线程;
当接收到加速终止提示信息时,确定所述加速终止提示信息指示的目标线程,并删除所述目标线程的预设标签。
由上可知,本申请实施例提供了一种电子设备,所述电子设备在接收到加速启动提示信息时,确定该加速启动提示信息指示的目标线程,将该目标线程标记为预设类型的线程。当需要对待调度线程进行分配处理器资源时,判断该待调度线程是否为预设类型的线程,如果是,则按照第一规则为其分配处理器资源,如果不是,则按照第二规则为其分配处理器资源,其中,基于第一规则为线程分配处理器资源的速度或数量,大于基于第二规则为线程分配器处理资源的速度或数量。通过这种方式,根据加速启动提示信息,将一些核心线程标记为预设类型的线程,进而将这些线程与其他的非核心线程区别开。并且,相对于非核心线程,在加速时间段内,为核心线程更多更快地分配处理器资源,以使这些线程能够更高效率地执行任务,以减少电子设备出现卡顿的现象。
本申请实施例还提供一种存储介质,所述存储介质中存储有计算机程序,当所述计算机程序在计算机上运行时,所述计算机执行上述任一实施例所述的资源分配方法。
需要说明的是,本领域普通技术人员可以理解上述实施例的各种方法中的全部或部分步骤是可以通过计算机程序来指令相关的硬件来完成,所述计算机程序可以存储于计算机可读存储介质中,所述存储介质可以包括但不限于:只读存储器(ROM,Read OnlyMemory)、随机存取存储器(RAM,Random Access Memory)、磁盘或光盘等。
此外,本申请中的术语“第一”、“第二”和“第三”等是用于区别不同对象,而不是用于描述特定顺序。此外,术语“包括”和“具有”以及它们任何变形,意图在于覆盖不排他的包含。例如包含了一系列步骤或模块的过程、方法、***、产品或设备没有限定于已列出的步骤或模块,而是某些实施例还包括没有列出的步骤或模块,或某些实施例还包括对于这些过程、方法、产品或设备固有的其它步骤或模块。
以上对本申请实施例所提供的资源分配方法、装置、存储介质及电子设备进行了详细介绍。本文中应用了具体个例对本申请的原理及实施方式进行了阐述,以上实施例的说明只是用于帮助理解本申请的方法及其核心思想;同时,对于本领域的技术人员,依据本申请的思想,在具体实施方式及应用范围上均会有改变之处,综上所述,本说明书内容不应理解为对本申请的限制。

Claims (11)

1.一种资源分配方法,其特征在于,包括:
当接收到加速启动提示信息时,确定所述加速启动提示信息指示的目标线程,并将所述目标线程标记为预设类型的线程;
当需要对待调度线程进行分配处理器资源时,判断所述待调度线程是否为预设类型的线程;
当所述待调度线程为所述预设类型的线程时,按照第一规则为所述待调度线程分配处理器资源;
当所述待调度线程不为所述预设类型的线程时,按照第二规则为所述待调度线程分配处理器资源,其中,基于所述第一规则为线程分配处理器资源的速度或数量,大于基于所述第二规则为线程分配器处理资源的速度或数量。
2.如权利要求1所述的资源分配方法,其特征在于,所述分配处理器资源为变更处理单元;所述按照第一规则为所述待调度线程分配处理器资源,包括:
从候选处理单元中确定出计算能力最大的候选处理单元,作为目标处理单元;
将所述待调度线程从当前所在的处理单元迁移至所述目标处理单元执行。
3.如权利要求1所述的资源分配方法,其特征在于,所述分配处理器资源为增大处理单元的工作频率;所述按照第一规则为所述待调度线程分配处理器资源,包括:
获取所述待调度线程对应的频率调整值;
根据所述频率调整值,增大所述待调度线程当前所在的处理单元的工作频率。
4.如权利要求1所述的资源分配方法,其特征在于,所述分配处理器资源为分配处理单元;所述按照第一规则为所述待调度线程分配处理器资源,包括:
从候选处理单元中确定出计算能力最大的候选处理单元,作为目标处理单元;
将所述待调度线程分配至所述目标处理单元进行执行。
5.如权利要求1所述的资源分配方法,其特征在于,所述当接收到加速启动提示信息时,确定所述加速启动提示信息指示的目标线程,并将所述目标线程标记为预设类型的线程之前,还包括:
当检测到执行预设事件时,确定执行所述预设事件所创建的目标线程,并基于所述目标线程生成加速启动提示信息。
6.如权利要求5所述的资源分配方法,其特征在于,所述方法应用于电子设备,所述预设事件为所述电子设备启动、应用程序启动或者应用程序安装。
7.如权利要求1至6任一项所述的资源分配方法,其特征在于,还包括:所述将所述目标线程标记为预设类型的线程,包括:
为所述目标线程添加预设标签,以将所述目标线程标记为预设类型的线程;
所述方法还包括:
当接收到加速终止提示信息时,确定所述加速终止提示信息指示的目标线程,并删除所述目标线程的预设标签。
8.如权利要求1至6任一项所述的资源分配方法,其特征在于,所述按照第二规则为所述待调度线程分配处理器资源,包括:
按照预设的线程调度规则为所述待调度线程分配处理器资源。
9.一种资源分配装置,其特征在于,包括:
线程标记模块,用于当接收到加速启动提示信息时,确定所述加速启动提示信息指示的目标线程,并将所述目标线程标记为预设类型的线程;
线程判断模块,用于当需要对待调度线程进行分配处理器资源时,判断所述待调度线程是否为预设类型的线程;
资源分配模块,用于当所述待调度线程为所述预设类型的线程时,按照第一规则为所述待调度线程分配处理器资源;
以及,当所述待调度线程不为所述预设类型的线程时,按照第二规则为所述待调度线程分配处理器资源,其中,基于所述第一规则为线程分配处理器资源的速度或数量,大于基于所述第二规则为线程分配器处理资源的速度或数量。
10.一种存储介质,其上存储有计算机程序,其特征在于,当所述计算机程序在计算机上运行时,使得所述计算机执行如权利要求1至8任一项所述的资源分配方法。
11.一种电子设备,包括处理器和存储器,所述存储器存储有计算机程序,其特征在于,所述处理器通过调用所述计算机程序,用于执行如权利要求1至8任一项所述的资源分配方法。
CN202010261311.9A 2020-04-03 2020-04-03 资源分配方法、装置、存储介质及电子设备 Pending CN113495787A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202010261311.9A CN113495787A (zh) 2020-04-03 2020-04-03 资源分配方法、装置、存储介质及电子设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202010261311.9A CN113495787A (zh) 2020-04-03 2020-04-03 资源分配方法、装置、存储介质及电子设备

Publications (1)

Publication Number Publication Date
CN113495787A true CN113495787A (zh) 2021-10-12

Family

ID=77995361

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202010261311.9A Pending CN113495787A (zh) 2020-04-03 2020-04-03 资源分配方法、装置、存储介质及电子设备

Country Status (1)

Country Link
CN (1) CN113495787A (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2024007970A1 (zh) * 2022-07-06 2024-01-11 华为技术有限公司 线程调度方法及电子设备
CN117931418A (zh) * 2022-10-26 2024-04-26 荣耀终端有限公司 资源管控方法、装置、芯片、电子设备及介质

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2024007970A1 (zh) * 2022-07-06 2024-01-11 华为技术有限公司 线程调度方法及电子设备
CN117931418A (zh) * 2022-10-26 2024-04-26 荣耀终端有限公司 资源管控方法、装置、芯片、电子设备及介质

Similar Documents

Publication Publication Date Title
US10628216B2 (en) I/O request scheduling method and apparatus by adjusting queue depth associated with storage device based on hige or low priority status
EP2893444B1 (en) Quota-based resource management
US8650570B2 (en) Method of assigning instructions in a process to a plurality of scheduler instances based on the instruction, in which each scheduler instance is allocated a set of negoitaited processor resources
CN111597042A (zh) 业务线程运行方法、装置、存储介质及电子设备
CN113495780A (zh) 任务调度方法、装置、存储介质及电子设备
CN110968415B (zh) 多核处理器的调度方法、装置及终端
CN111475299B (zh) 内存分配方法、装置、存储介质及电子设备
CN111831438A (zh) 资源分配方法、装置、存储介质及电子设备
CN111831414A (zh) 线程迁移方法、装置、存储介质及电子设备
CN111831434A (zh) 资源分配方法、装置、存储介质及电子设备
CN111813521A (zh) 线程调度方法、装置、存储介质及电子设备
CN111831433A (zh) 资源分配方法、装置、存储介质及电子设备
CN113495787A (zh) 资源分配方法、装置、存储介质及电子设备
US20200379804A1 (en) Multi-level scheduling
CN113535251A (zh) 一种线程管理方法及装置
CN111831432B (zh) Io请求的调度方法、装置、存储介质及电子设备
CN116578422B (zh) 资源分配方法和电子设备
KR20200125258A (ko) 어플리케이션 실행을 제어하기 위한 방법, 이를 위한 전자 장치 및 저장 매체
CN111831436A (zh) Io请求的调度方法、装置、存储介质及电子设备
CN111831439A (zh) Io请求的处理方法、装置、存储介质及电子设备
CN111831437A (zh) 设备管理方法、装置、存储介质及电子设备
CN111831442A (zh) 一种资源分配的方法、装置、存储介质及电子设备
CN111831409B (zh) 线程调度方法、装置、存储介质及电子设备
CN116069209A (zh) 焦点窗口处理方法、装置、设备和存储介质
CN111078405B (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