CN114449094A - 管控方法及电子设备 - Google Patents
管控方法及电子设备 Download PDFInfo
- Publication number
- CN114449094A CN114449094A CN202011194269.XA CN202011194269A CN114449094A CN 114449094 A CN114449094 A CN 114449094A CN 202011194269 A CN202011194269 A CN 202011194269A CN 114449094 A CN114449094 A CN 114449094A
- Authority
- CN
- China
- Prior art keywords
- read
- application
- write
- period
- total
- 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
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M1/00—Substation equipment, e.g. for use by subscribers
- H04M1/72—Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
- H04M1/724—User interfaces specially adapted for cordless or mobile telephones
- H04M1/72403—User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality
- H04M1/7243—User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality with interactive means for internal management of messages
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M1/00—Substation equipment, e.g. for use by subscribers
- H04M1/72—Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
- H04M1/724—User interfaces specially adapted for cordless or mobile telephones
- H04M1/72448—User interfaces specially adapted for cordless or mobile telephones with means for adapting the functionality of the device according to specific conditions
-
- Y—GENERAL 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
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE 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/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Human Computer Interaction (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Business, Economics & Management (AREA)
- General Business, Economics & Management (AREA)
- Telephone Function (AREA)
Abstract
本申请实施例提供了一种管控方法及电子设备,该管控方法包括:应用在电子设备的后台的运行时,电子设备可周期性地对该应用在周期内的读写总量进行监控,并在应用的读写总量满足设定的管控条件时,对该应用的读写操作进行管控,以限制其在单位时间内的读写总量,从而实现对后台应用的读写操作的实时监控与管理,以降低后台应用大量读写对前台应用读写操作的影响,进而提升用户使用体验。
Description
技术领域
本申请实施例涉及终端设备领域,尤其涉及一种管控方法及电子设备。
背景技术
随着手机中的应用越来越多,多个应用同时触发读写,尤其是后台应用触发进行大量的读写操作时,其不断地与存储进行数据交互,将会造成前台应用卡顿的问题,影响用户的使用体验。
发明内容
为了解决上述技术问题,本申请提供一种管控方法及电子设备。在该方法中,电子设备可通过对后台应用的读写操作进行监控,以在后台应用的读写操作满足管控条件的情况下,对后台应用的读写操作进行管控,从而有效防止后台应用大量读写造成的前台应用卡顿问题,提升用户使用体验。
第一方面,本申请实施例提供一种管控方法。该方法包括:在第一电子设备上的后台运行第一应用的过程中,获取第一应用在第一周期内的第一读写总量;第一电子设备基于第一读写总量,判断第一应用是否满足设定的管控条件。当第一应用满足管控条件时,第一电子设备对第一应用在第二周期内的读写操作进行管控,管控后的第一应用在第二周期内的第二读写总量小于管控阈值。这样,第一电子设备可对运行在后台的后台应用进行实时监控,以在后台应用的读写总量较大时,及时对后台应用的读写总量进行管控,以限制其读写量,从而降低后台应用的读写资源占比,将资源更多地分配给前台应用,以避免前台应用卡顿的问题,从而提升用户使用体验。
根据第一方面,第一周期与第二周期为相邻周期,第一周期与第二周期的时长相同或不同。这样,电子设备可在确定需要对后台应用进行管控的情况下,在下一个相邻周期对后台应用进行管控。
示例性的,第一周期时长可以为1s,第二周期时长可以为1s,也可以为125ms,还可以是大于1s的数值,本申请不做限定。
根据第一方面,或者以上第一方面的任意一种实现方式,管控条件包括以下至少之一:所述第一读写总量为已获取的多个应用的读写总量前N个最大的读写总量中的一个,所述N为大于或等于1的整数,所述多个应用的读写总量为在所述第一周期内获取到的;所述第一读写总量大于或等于第一阈值。这样,电子设备可通过预设管控条件,以判定是否需要对后台应用进行管控。
示例性的,所述已获取的多个读写总量均为正在运行的后台应用在第一周期内对应的读写总量。
根据第一方面,或者以上第一方面的任意一种实现方式,对第一应用在第二周期内的读写操作进行管控,包括:当所述第一应用在所述第二周期内进行第一读写操作,获取所述第一应用在所述第二周期时间内的第二读写总量;其中,所述第一读写操作对应的读写量为第三读写量;当所述第三读写量与所述第二读写总量之和大于或等于所述管控阈值,将所述第一读写操作对应的数据输入至缓存中;当所述第三读写量与所述第二读写总量之和小于所述管控阈值,将所述第一读写操作对应的数据输入至缓存中,并通过所述缓存将数据写入存储中。这样,若电子设备确定需要对后台应用进行管控,则其可通过限制应用在第二周期内向存储写入,以实现对后台应用的读写管控。
示例性的,电子设备除可限制应用的写入操作,还可以限制应用的读取操作,若电子设备需要对读取操作进行管控,则电子设备限制应用从存储中读取相应的数据。
示例性的,若电子设备确定无需对后台应用的读取操作进行管控,电子设备可从存储读取对应的数据,并将数据输入至缓存,以及,通过缓存将数据输出至应用。
根据第一方面,或者以上第一方面的任意一种实现方式,在第一电子设备上的后台运行第一应用的过程中,第一电子设备还在后台运行第二应用,方法还包括:第一电子设备获取第二应用在第一周期内的第三读写总量;基于第三读写总量,判断第二应用是否满足管控条件;若第二应用满足管控条件,第一电子设备对第二应用在第二周期内的读写操作进行管控,管控后的第二应用在第二周期内的第四读写总量与第二读写总量之和小于管控阈值。这样,电子设备可实现对多个后台应用的监控与管理。
根据第一方面,或者以上第一方面的任意一种实现方式,第一电子设备对第二应用在第二周期内的读写操作进行管控,包括:当所述第一应用进行第一读写操作,获取所述第一应用在所述第二周期内的第二读写总量以及所述第二应用在所述第二周期内的第四读写总量;其中,所述第一读写操作对应的读写量为第三读写量;当所述第三读写量、所述第二读写总量与所述第四读写总量之和大于或等于所述管控阈值,在所述第二周期时间内将所述第一应用的第一读写操作对应的数据写入缓存中,以及,在所述第二周期内将所述第二应用的读写操作对应的数据写入所述缓存中;当所述第三读写量、所述第二读写总量与所述第四读写总量之和大于或等于所述管控阈值,将所述第一读写操作对应的数据输入至缓存中,并通过所述缓存将数据写入存储中,以及,在所述第二周期内将所述第二应用的读写操作对应的数据输入至缓存中,并通过所述缓存将数据写入存储中。这样,当需要对多个后台应用进行管控时,电子设备限制被管控的多个应用在第二周期内与存储之间的数据交互。
根据第一方面,或者以上第一方面的任意一种实现方式,方法还包括:第一电子设备按照设定的触发条件,更新管控阈值。这样,电子设备可定时对管控阈值进行更新,从而使得管控阈值可基于电子设备的状态设置。
示例性的,触发条件可以为周期时长,例如,每一个月或者每一周更新一次管控阈值。
根据第一方面,或者以上第一方面的任意一种实现方式,在第一电子设备上的后台运行第一应用的过程中,第一电子设备还运行第三应用,方法还包括:第一电子设备获取第三应用在第一周期内的第五读写总量,第五读写总量小于第一读写总量;第一电子设备基于第五读写总量,判定第三应用不满足管控条件,确定不需要对第三应用在第二周期内的读写操作进行管控。这样,电子设备对后台应用进行监控时,若后台应用的读写总量较小,即不满足管控条件时,电子设备可不对该后台应用的读写操作进行限制。
根据第一方面,或者以上第一方面的任意一种实现方式,第一电子设备获取第一应用在第一周期内的第一读写总量,包括:第一电子设备获取第一应用在第一周期内的多次读写操作中每次读写操作对应的读写量;第一电子设备获取每次读写操作对应的读写量之和,读写量之和为第一读写总量。这样,电子设备可通过统计后台应用在周期内的多次读写的总量,以基于周期内的读写总量对后台应用进行管控。
根据第一方面,或者以上第一方面的任意一种实现方式,第一电子设备获取第一应用在第一周期内的第一读写总量,包括:第一电子设备在所述第一应用在所述第一周期内进行第一次读写操作时,设置第一输入输出IO时间戳;在所述第一应用进行第M次读写操作时,检测所述第M次读写操作对应的时刻与所述IO时间戳之间的相对时长是否大于或等于所述第一周期的周期时长;其中,M为大于1的整数;当所述相对时长大于或等于所述第一周期的周期时长,获取所述第一应用在所述第一周期内的第一读写总量,所述第一读写总量为M次读写操作对应的读写量之和。这样,第一电子设备可通过维护IO时间戳以及应用时间戳,实现对后台应用的读写操作的监控。
根据第一方面,或者以上第一方面的任意一种实现方式,若满足下述条件中的至少一个,第一电子设备获取第一应用在第一周期内的第一读写总量:所述第一电子设备为非息屏状态;所述第一电子设备在前台运行一个或多个应用;所述第一电子设备中运行的各应用的读写总量大于第一阈值;所述一个或多个应用的读写总量大于第二阈值。这样,电子设备可通过设置触发条件,以在触发条件被触发的情况下,执行对后台应用的管控,从而降低电子设备的功耗。
第二方面,本申请实施例提供一种电子设备。该电子设备包括一个或多个处理器;存储器;以及一个或多个计算机程序,其中一个或多个计算机程序存储在存储器上,当计算机程序被一个或多个处理器执行时,使得电子设备执行以下步骤:在电子设备上的后台运行第一应用的过程中,获取第一应用在第一周期内的第一读写总量;基于第一读写总量,判断第一应用是否满足设定的管控条件;当第一应用满足管控条件时,对第一应用在第二周期内的读写操作进行管控,管控后的第一应用在第二周期内的第二读写总量小于管控阈值。
根据第二方面,第一周期与第二周期为相邻周期,第一周期与第二周期的时长相同或不同。
根据第二方面,或者以上第二方面的任意一种实现方式,管控条件包括以下至少之一:所述第一读写总量为已获取的多个应用的读写总量前N个最大的读写总量中的一个,所述N为大于或等于1的整数,所述多个应用的读写总量为在所述第一周期内获取到的;所述第一读写总量大于或等于第一阈值。
根据第二方面,或者以上第二方面的任意一种实现方式,当计算机程序被一个或多个处理器执行时,使得电子设备执行以下步骤:当所述第一应用在所述第二周期内进行第一读写操作,获取所述第一应用在所述第二周期时间内的第二读写总量;其中,所述第一读写操作对应的读写量为第三读写量;当所述第三读写量与所述第二读写总量之和大于或等于所述管控阈值,将所述第一读写操作对应的数据输入至缓存中;当所述第三读写量与所述第二读写总量之和小于所述管控阈值,将所述第一读写操作对应的数据输入至缓存中,并通过所述缓存将数据写入存储中。
根据第二方面,或者以上第二方面的任意一种实现方式,在电子设备上的后台运行第一应用的过程中,电子设备还在后台运行第二应用,当计算机程序被一个或多个处理器执行时,使得电子设备执行以下步骤:获取第二应用在第一周期内的第三读写总量;基于第三读写总量,判断第二应用是否满足管控条件;若第二应用满足管控条件,对第二应用在第二周期内的读写操作进行管控,管控后的第二应用在第二周期内的第四读写总量与第二读写总量之和小于管控阈值。
根据第二方面,或者以上第二方面的任意一种实现方式,其特征在于当计算机程序被一个或多个处理器执行时,使得电子设备执行以下步骤:当所述第一应用进行第一读写操作,获取所述第一应用在所述第二周期内的第二读写总量以及所述第二应用在所述第二周期内的第四读写总量;其中,所述第一读写操作对应的读写量为第三读写量;当所述第三读写量、所述第二读写总量与所述第四读写总量之和大于或等于所述管控阈值,在所述第二周期时间内将所述第一应用的第一读写操作对应的数据写入缓存中,以及,在所述第二周期内将所述第二应用的读写操作对应的数据写入所述缓存中;当所述第三读写量、所述第二读写总量与所述第四读写总量之和大于或等于所述管控阈值,将所述第一读写操作对应的数据输入至缓存中,并通过所述缓存将数据写入存储中,以及,在所述第二周期内将所述第二应用的读写操作对应的数据输入至缓存中,并通过所述缓存将数据写入存储中。
根据第二方面,或者以上第二方面的任意一种实现方式,当计算机程序被一个或多个处理器执行时,使得电子设备执行以下步骤:按照设定的触发条件,更新管控阈值。
根据第二方面,或者以上第二方面的任意一种实现方式,在电子设备上的后台运行第一应用的过程中,电子设备还运行第三应用,当计算机程序被一个或多个处理器执行时,使得电子设备执行以下步骤:获取所述第三应用在所述第一周期内的第五读写总量,所述第五读写总量小于所述第一读写总量;基于所述第五读写总量,判定所述第三应用不满足所述管控条件,确定不需要对所述第三应用在所述第二周期内的读写操作进行所述管控。
根据第二方面,或者以上第二方面的任意一种实现方式,当计算机程序被一个或多个处理器执行时,使得电子设备执行以下步骤:获取第一应用在第一周期内的多次读写操作中每次读写操作对应的读写量;获取每次读写操作对应的读写量之和,读写量之和为第一读写总量。
根据第二方面,或者以上第二方面的任意一种实现方式,当计算机程序被一个或多个处理器执行时,使得电子设备执行以下步骤:在所述第一应用在所述第一周期内进行第一次读写操作时,设置第一输入输出IO时间戳;在所述第一应用进行第M次读写操作时,检测所述第M次读写操作对应的时刻与所述IO时间戳之间的相对时长是否大于或等于所述第一周期的周期时长;其中,M为大于1的整数;当所述相对时长大于或等于所述第一周期的周期时长,获取所述第一应用在所述第一周期内的第一读写总量,所述第一读写总量为M次读写操作对应的读写量之和。
根据第二方面,或者以上第二方面的任意一种实现方式,当计算机程序被一个或多个处理器执行时,使得电子设备在满足下述条件中的至少一个,获取第一应用在第一周期内的第一读写总量:电子设备为非息屏状态;电子设备在前台运行一个或多个应用;电子设备中运行的各应用的读写总量大于第一阈值;一个或多个应用的读写总量大于第二阈值。
第二方面以及第二方面的任意一种实现方式分别与第一方面以及第一方面的任意一种实现方式相对应。第二方面以及第二方面的任意一种实现方式所对应的技术效果可参见上述第一方面以及第一方面的任意一种实现方式所对应的技术效果,此处不再赘述
第三方面,本申请实施例提供一种芯片。该芯片包括一个或多个接口电路和一个或多个处理器;接口电路用于从电子设备的存储器接收信号,并向处理器发送信号,信号包括存储器中存储的计算机指令;当处理器执行计算机指令时,使得电子设备执行第一方面以及第一方面中任意一项的管控方法。
第三方面以及第三方面的任意一种实现方式分别与第一方面以及第一方面的任意一种实现方式相对应。第三方面以及第三方面的任意一种实现方式所对应的技术效果可参见上述第一方面以及第一方面的任意一种实现方式所对应的技术效果,此处不再赘述。
第四方面,本申请实施例提供一种计算机可读存储介质。该计算机可读存储介质包括计算机程序,其特征在于,当计算机程序在电子设备上运行时,使得电子设备执行第一方面以及第一方面中任意一项的的管控方法。
第四方面以及第四方面的任意一种实现方式分别与第一方面以及第一方面的任意一种实现方式相对应。第四方面以及第四方面的任意一种实现方式所对应的技术效果可参见上述第一方面以及第一方面的任意一种实现方式所对应的技术效果,此处不再赘述。
附图说明
图1为示例性示出的手机的结构示意图;
图2为示例性示出的手机的软件结构示意图;
图3为示例性示出的模块交互示意图;
图4为示例性示出的模块交互示意图;
图5为示例性示出的用户界面示意图;
图6为示例性示出的模块交互示意图;
图7a为示例性示出的CPU Cgroup模块的分组示意图;
图7b为示例性示出的IO Cgroup模块的分组示意图;
图8a~图8b为示例性示出的用户界面示意图;
图9为示例性示出的模块交互示意图;
图10为示例性示出的CPU Cgroup模块的分组示意图;
图11为示例性示出的IO时间戳、应用时间戳以及参考时间轴的示意图;
图12为示例性示出的模块交互示意图;
图13为示例性示出的IO时间戳、应用时间戳以及参考时间轴的示意图;
图14为示例性示出的IO时间戳、应用时间戳以及参考时间轴的示意图;
图15为示例性示出的后台高IO识别模块的步骤流程图;
图16为示例性示出的模块交互示意图;
图17为示例性示出的IO时间戳、应用时间戳以及参考时间轴的示意图;
图18为示例性示出的后台高IO识别模块的步骤流程图;
图19为示例性示出的IO Cgroup模块的分组示意图;
图20为示例性示出的IO时间戳、应用时间戳以及参考时间轴的示意图;
图21为示例性示出的IO管控模块对应用的管控流程示意图;
图22为示例性示出的管控阈值的获取方式的示意图;
图23为示例性示出的一种装置的结构示意图。
具体实施方式
下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
本文中术语“和/或”,仅仅是一种描述关联对象的关联关系,表示可以存在三种关系,例如,A和/或B,可以表示:单独存在A,同时存在A和B,单独存在B这三种情况。
本申请实施例的说明书和权利要求书中的术语“第一”和“第二”等是用于区别不同的对象,而不是用于描述对象的特定顺序。例如,第一目标对象和第二目标对象等是用于区别不同的目标对象,而不是用于描述目标对象的特定顺序。
在本申请实施例中,“示例性的”或者“例如”等词用于表示作例子、例证或说明。本申请实施例中被描述为“示例性的”或者“例如”的任何实施例或设计方案不应被解释为比其它实施例或设计方案更优选或更具优势。确切而言,使用“示例性的”或者“例如”等词旨在以具体方式呈现相关概念。
在本申请实施例的描述中,除非另有说明,“多个”的含义是指两个或两个以上。例如,多个处理单元是指两个或两个以上的处理单元;多个系统是指两个或两个以上的系统。
本申请实施例中的技术方案可适用于终端,也可以称为移动台(mobilestation),用户单元(subscriber unit),站点(station),终端设备(terminal equipment,TE)等。终端可以为蜂窝电话(cellular phone),平板电脑(pad)、个人电脑(personalcomputer)、可穿戴设备或物联网设备等,本申请不做限定。
如图1所示为终端为手机时的结构示意图,应该理解的是,图1所示手机100仅是终端的一个范例,并且手机100可以具有比图中所示的更多的或者更少的部件,可以组合两个或多个的部件,或者可以具有不同的部件配置。图1中所示出的各种部件可以在包括一个或多个信号处理和/或专用集成电路在内的硬件、软件、或硬件和软件的组合中实现。
手机100可以包括:处理器110,外部存储器接口120,内部存储器121,通用串行总线(universal serial bus,USB)接口130,充电管理模块140,电源管理模块141,电池142,天线1,天线2,移动通信模块150,无线通信模块160,音频模块170,扬声器170A,受话器170B,麦克风170C,耳机接口170D,传感器模块180,按键190,马达191,指示器192,摄像头193,显示屏194,以及用户标识模块(subscriber identification module,SIM)卡接口195等。其中传感器模块180可以包括压力传感器180A,陀螺仪传感器180B,气压传感器180C,磁传感器180D,加速度传感器180E,距离传感器180F,接近光传感器180G,指纹传感器180H,温度传感器180J,触摸传感器180K,环境光传感器180L,骨传导传感器180M等。
可以理解的是,本发明实施例示意的结构并不构成对手机100的具体限定。在本申请另一些实施例中,手机100可以包括比图示更多或更少的部件,或者组合某些部件,或者拆分某些部件,或者不同的部件布置。图示的部件可以以硬件,软件或软件和硬件的组合实现。
处理器110可以包括一个或多个处理单元,例如:处理器110可以包括应用处理器(application processor,AP),调制解调处理器,图形处理器(graphics processingunit,GPU),图像信号处理器(image signal processor,ISP),控制器,存储器,视频编解码器,数字信号处理器(digital signal processor,DSP),基带处理器,和/或神经网络处理器(neural-network processing unit,NPU)等。其中,不同的处理单元可以是独立的器件,也可以集成在一个或多个处理器中。
其中,控制器可以是手机100的神经中枢和指挥中心。控制器可以根据指令操作码和时序信号,产生操作控制信号,完成取指令和执行指令的控制。
处理器110中还可以设置存储器,用于存储指令和数据。在一些实施例中,处理器110中的存储器为高速缓冲存储器。该存储器可以保存处理器110刚用过或循环使用的指令或数据。如果处理器110需要再次使用该指令或数据,可从所述存储器中直接调用。避免了重复存取,减少了处理器110的等待时间,因而提高了系统的效率。
在一些实施例中,处理器110可以包括一个或多个接口。接口可以包括集成电路(inter-integrated circuit,I2C)接口,集成电路内置音频(inter-integrated circuitsound,I2S)接口,脉冲编码调制(pulse code modulation,PCM)接口,通用异步收发传输器(universal asynchronous receiver/transmitter,UART)接口,移动产业处理器接口(mobile industry processor interface,MIPI),通用输入输出(general-purposeinput/output,GPIO)接口,用户标识模块(subscriber identity module,SIM)接口,和/或通用串行总线(universal serial bus,USB)接口等。
I2C接口是一种双向同步串行总线,包括一根串行数据线(serial data line,SDA)和一根串行时钟线(derail clock line,SCL)。在一些实施例中,处理器110可以包含多组I2C总线。处理器110可以通过不同的I2C总线接口分别耦合触摸传感器180K,充电器,闪光灯,摄像头193等。例如:处理器110可以通过I2C接口耦合触摸传感器180K,使处理器110与触摸传感器180K通过I2C总线接口通信,实现手机100的触摸功能。
I2S接口可以用于音频通信。在一些实施例中,处理器110可以包含多组I2S总线。处理器110可以通过I2S总线与音频模块170耦合,实现处理器110与音频模块170之间的通信。在一些实施例中,音频模块170可以通过I2S接口向无线通信模块160传递音频信号,实现通过蓝牙耳机接听电话的功能。
PCM接口也可以用于音频通信,将模拟信号抽样,量化和编码。在一些实施例中,音频模块170与无线通信模块160可以通过PCM总线接口耦合。在一些实施例中,音频模块170也可以通过PCM接口向无线通信模块160传递音频信号,实现通过蓝牙耳机接听电话的功能。所述I2S接口和所述PCM接口都可以用于音频通信。
UART接口是一种通用串行数据总线,用于异步通信。该总线可以为双向通信总线。它将要传输的数据在串行通信与并行通信之间转换。在一些实施例中,UART接口通常被用于连接处理器110与无线通信模块160。例如:处理器110通过UART接口与无线通信模块160中的蓝牙模块通信,实现蓝牙功能。在一些实施例中,音频模块170可以通过UART接口向无线通信模块160传递音频信号,实现通过蓝牙耳机播放音乐的功能。
MIPI接口可以被用于连接处理器110与显示屏194,摄像头193等外围器件。MIPI接口包括摄像头串行接口(camera serial interface,CSI),显示屏串行接口(displayserial interface,DSI)等。在一些实施例中,处理器110和摄像头193通过CSI接口通信,实现手机100的拍摄功能。处理器110和显示屏194通过DSI接口通信,实现手机100的显示功能。
GPIO接口可以通过软件配置。GPIO接口可以被配置为控制信号,也可被配置为数据信号。在一些实施例中,GPIO接口可以用于连接处理器110与摄像头193,显示屏194,无线通信模块160,音频模块170,传感器模块180等。GPIO接口还可以被配置为I2C接口,I2S接口,UART接口,MIPI接口等。
USB接口130是符合USB标准规范的接口,具体可以是Mini USB接口,Micro USB接口,USB Type C接口等。USB接口130可以用于连接充电器为手机100充电,也可以用于手机100与外围设备之间传输数据。也可以用于连接耳机,通过耳机播放音频。该接口还可以用于连接其他手机,例如AR设备等。
可以理解的是,本发明实施例示意的各模块间的接口连接关系,只是示意性说明,并不构成对手机100的结构限定。在本申请另一些实施例中,手机100也可以采用上述实施例中不同的接口连接方式,或多种接口连接方式的组合。
充电管理模块140用于从充电器接收充电输入。其中,充电器可以是无线充电器,也可以是有线充电器。在一些有线充电的实施例中,充电管理模块140可以通过USB接口130接收有线充电器的充电输入。在一些无线充电的实施例中,充电管理模块140可以通过手机100的无线充电线圈接收无线充电输入。充电管理模块140为电池142充电的同时,还可以通过电源管理模块141为手机供电。
电源管理模块141用于连接电池142,充电管理模块140与处理器110。电源管理模块141接收电池142和/或充电管理模块140的输入,为处理器110,内部存储器121,外部存储器,显示屏194,摄像头193,和无线通信模块160等供电。电源管理模块141还可以用于监测电池容量,电池循环次数,电池健康状态(漏电,阻抗)等参数。在其他一些实施例中,电源管理模块141也可以设置于处理器110中。在另一些实施例中,电源管理模块141和充电管理模块140也可以设置于同一个器件中。
手机100的无线通信功能可以通过天线1,天线2,移动通信模块150,无线通信模块160,调制解调处理器以及基带处理器等实现。
天线1和天线2用于发射和接收电磁波信号。手机100中的每个天线可用于覆盖单个或多个通信频带。不同的天线还可以复用,以提高天线的利用率。例如:可以将天线1复用为无线局域网的分集天线。在另外一些实施例中,天线可以和调谐开关结合使用。
移动通信模块150可以提供应用在手机100上的包括2G/3G/4G/5G等无线通信的解决方案。移动通信模块150可以包括至少一个滤波器,开关,功率放大器,低噪声放大器(lownoise amplifier,LNA)等。移动通信模块150可以由天线1接收电磁波,并对接收的电磁波进行滤波,放大等处理,传送至调制解调处理器进行解调。移动通信模块150还可以对经调制解调处理器调制后的信号放大,经天线1转为电磁波辐射出去。在一些实施例中,移动通信模块150的至少部分功能模块可以被设置于处理器110中。在一些实施例中,移动通信模块150的至少部分功能模块可以与处理器110的至少部分模块被设置在同一个器件中。
调制解调处理器可以包括调制器和解调器。其中,调制器用于将待发送的低频基带信号调制成中高频信号。解调器用于将接收的电磁波信号解调为低频基带信号。随后解调器将解调得到的低频基带信号传送至基带处理器处理。低频基带信号经基带处理器处理后,被传递给应用处理器。应用处理器通过音频设备(不限于扬声器170A,受话器170B等)输出声音信号,或通过显示屏194显示图像或视频。在一些实施例中,调制解调处理器可以是独立的器件。在另一些实施例中,调制解调处理器可以独立于处理器110,与移动通信模块150或其他功能模块设置在同一个器件中。
无线通信模块160可以提供应用在手机100上的包括无线局域网(wireless localarea networks,WLAN)(如无线保真(wireless fidelity,Wi-Fi)网络),蓝牙(bluetooth,BT),全球导航卫星系统(global navigation satellite system,GNSS),调频(frequencymodulation,FM),近距离无线通信技术(near field communication,NFC),红外技术(infrared,IR)等无线通信的解决方案。无线通信模块160可以是集成至少一个通信处理模块的一个或多个器件。无线通信模块160经由天线2接收电磁波,将电磁波信号调频以及滤波处理,将处理后的信号发送到处理器110。无线通信模块160还可以从处理器110接收待发送的信号,对其进行调频,放大,经天线2转为电磁波辐射出去。
在一些实施例中,手机100的天线1和移动通信模块150耦合,天线2和无线通信模块160耦合,使得手机100可以通过无线通信技术与网络以及其他设备通信。所述无线通信技术可以包括全球移动通讯系统(global system for mobile communications,GSM),通用分组无线服务(general packet radio service,GPRS),码分多址接入(code divisionmultiple access,CDMA),宽带码分多址(wideband code division multiple access,WCDMA),时分码分多址(time-division code division multiple access,TD-SCDMA),长期演进(long term evolution,LTE),BT,GNSS,WLAN,NFC,FM,和/或IR技术等。所述GNSS可以包括全球卫星定位系统(global positioning system,GPS),全球导航卫星系统(globalnavigation satellite system,GLONASS),北斗卫星导航系统(beidou navigationsatellite system,BDS),准天顶卫星系统(quasi-zenith satellite system,QZSS)和/或星基增强系统(satellite based augmentation systems,SBAS)。
手机100通过GPU,显示屏194,以及应用处理器等实现显示功能。GPU为图像处理的微处理器,连接显示屏194和应用处理器。GPU用于执行数学和几何计算,用于图形渲染。处理器110可包括一个或多个GPU,其执行程序指令以生成或改变显示信息。
显示屏194用于显示图像,视频等。显示屏194包括显示面板。显示面板可以采用液晶显示屏(liquid crystal display,LCD),有机发光二极管(organic light-emittingdiode,OLED),有源矩阵有机发光二极体或主动矩阵有机发光二极体(active-matrixorganic light emitting diode的,AMOLED),柔性发光二极管(flex light-emittingdiode,FLED),Miniled,MicroLed,Micro-oLed,量子点发光二极管(quantum dot lightemitting diodes,QLED)等。在一些实施例中,手机100可以包括1个或N个显示屏194,N为大于1的正整数。
手机100可以通过ISP,摄像头193,视频编解码器,GPU,显示屏194以及应用处理器等实现拍摄功能。
ISP用于处理摄像头193反馈的数据。例如,拍照时,打开快门,光线通过镜头被传递到摄像头感光元件上,光信号转换为电信号,摄像头感光元件将所述电信号传递给ISP处理,转化为肉眼可见的图像。ISP还可以对图像的噪点,亮度,肤色进行算法优化。ISP还可以对拍摄场景的曝光,色温等参数优化。在一些实施例中,ISP可以设置在摄像头193中。
摄像头193用于捕获静态图像或视频。物体通过镜头生成光学图像投射到感光元件。感光元件可以是电荷耦合器件(charge coupled device,CCD)或互补金属氧化物半导体(complementary metal-oxide-semiconductor,CMOS)光电晶体管。感光元件把光信号转换成电信号,之后将电信号传递给ISP转换成数字图像信号。ISP将数字图像信号输出到DSP加工处理。DSP将数字图像信号转换成标准的RGB,YUV等格式的图像信号。在一些实施例中,手机100可以包括1个或N个摄像头193,N为大于1的正整数。
数字信号处理器用于处理数字信号,除了可以处理数字图像信号,还可以处理其他数字信号。例如,当手机100在频点选择时,数字信号处理器用于对频点能量进行傅里叶变换等。
视频编解码器用于对数字视频压缩或解压缩。手机100可以支持一种或多种视频编解码器。这样,手机100可以播放或录制多种编码格式的视频,例如:动态图像专家组(moving picture experts group,MPEG)1,MPEG2,MPEG3,MPEG4等。
NPU为神经网络(neural-network,NN)计算处理器,通过借鉴生物神经网络结构,例如借鉴人脑神经元之间传递模式,对输入信息快速处理,还可以不断的自学习。通过NPU可以实现手机100的智能认知等应用,例如:图像识别,人脸识别,语音识别,文本理解等。
外部存储器接口120可以用于连接外部存储卡,例如Micro SD卡,实现扩展手机100的存储能力。外部存储卡通过外部存储器接口120与处理器110通信,实现数据存储功能。例如将音乐,视频等文件保存在外部存储卡中。
内部存储器121可以用于存储计算机可执行程序代码,所述可执行程序代码包括指令。处理器110通过运行存储在内部存储器121的指令,从而执行手机100的各种功能应用以及数据处理。内部存储器121可以包括存储程序区和存储数据区。其中,存储程序区可存储操作系统,至少一个功能所需的应用程序(比如声音播放功能,图像播放功能等)等。存储数据区可存储手机100使用过程中所创建的数据(比如音频数据,电话本等)等。此外,内部存储器121可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件,闪存器件,通用闪存存储器(universal flash storage,UFS)等。
手机100可以通过音频模块170,扬声器170A,受话器170B,麦克风170C,耳机接口170D,以及应用处理器等实现音频功能。例如音乐播放,录音等。
音频模块170用于将数字音频信息转换成模拟音频信号输出,也用于将模拟音频输入转换为数字音频信号。音频模块170还可以用于对音频信号编码和解码。在一些实施例中,音频模块170可以设置于处理器110中,或将音频模块170的部分功能模块设置于处理器110中。
扬声器170A,也称“喇叭”,用于将音频电信号转换为声音信号。手机100可以通过扬声器170A收听音乐,或收听免提通话。
受话器170B,也称“听筒”,用于将音频电信号转换成声音信号。当手机100接听电话或语音信息时,可以通过将受话器170B靠近人耳接听语音。
麦克风170C,也称“话筒”,“传声器”,用于将声音信号转换为电信号。当拨打电话或发送语音信息时,用户可以通过人嘴靠近麦克风170C发声,将声音信号输入到麦克风170C。手机100可以设置至少一个麦克风170C。在另一些实施例中,手机100可以设置两个麦克风170C,除了采集声音信号,还可以实现降噪功能。在另一些实施例中,手机100还可以设置三个,四个或更多麦克风170C,实现采集声音信号,降噪,还可以识别声音来源,实现定向录音功能等。
耳机接口170D用于连接有线耳机。耳机接口170D可以是USB接口130,也可以是3.5mm的开放移动手机平台(open mobile terminal platform,OMTP)标准接口,美国蜂窝电信工业协会(cellular telecommunications industry association of the USA,CTIA)标准接口。
压力传感器180A用于感受压力信号,可以将压力信号转换成电信号。在一些实施例中,压力传感器180A可以设置于显示屏194。压力传感器180A的种类很多,如电阻式压力传感器,电感式压力传感器,电容式压力传感器等。电容式压力传感器可以是包括至少两个具有导电材料的平行板。当有力作用于压力传感器180A,电极之间的电容改变。手机100根据电容的变化确定压力的强度。当有触摸操作作用于显示屏194,手机100根据压力传感器180A检测所述触摸操作强度。手机100也可以根据压力传感器180A的检测信号计算触摸的位置。在一些实施例中,作用于相同触摸位置,但不同触摸操作强度的触摸操作,可以对应不同的操作指令。例如:当有触摸操作强度小于第一压力阈值的触摸操作作用于短消息应用图标时,执行查看短消息的指令。当有触摸操作强度大于或等于第一压力阈值的触摸操作作用于短消息应用图标时,执行新建短消息的指令。
陀螺仪传感器180B可以用于确定手机100的运动姿态。在一些实施例中,可以通过陀螺仪传感器180B确定手机100围绕三个轴(即,x,y和z轴)的角速度。陀螺仪传感器180B可以用于拍摄防抖。示例性的,当按下快门,陀螺仪传感器180B检测手机100抖动的角度,根据角度计算出镜头模组需要补偿的距离,让镜头通过反向运动抵消手机100的抖动,实现防抖。陀螺仪传感器180B还可以用于导航,体感游戏场景。
气压传感器180C用于测量气压。在一些实施例中,手机100通过气压传感器180C测得的气压值计算海拔高度,辅助定位和导航。
磁传感器180D包括霍尔传感器。手机100可以利用磁传感器180D检测翻盖皮套的开合。在一些实施例中,当手机100是翻盖机时,手机100可以根据磁传感器180D检测翻盖的开合。进而根据检测到的皮套的开合状态或翻盖的开合状态,设置翻盖自动解锁等特性。
加速度传感器180E可检测手机100在各个方向上(一般为三轴)加速度的大小。当手机100静止时可检测出重力的大小及方向。还可以用于识别手机姿态,应用于横竖屏切换,计步器等应用。
距离传感器180F,用于测量距离。手机100可以通过红外或激光测量距离。在一些实施例中,拍摄场景,手机100可以利用距离传感器180F测距以实现快速对焦。
接近光传感器180G可以包括例如发光二极管(LED)和光检测器,例如光电二极管。发光二极管可以是红外发光二极管。手机100通过发光二极管向外发射红外光。手机100使用光电二极管检测来自附近物体的红外反射光。当检测到充分的反射光时,可以确定手机100附近有物体。当检测到不充分的反射光时,手机100可以确定手机100附近没有物体。手机100可以利用接近光传感器180G检测用户手持手机100贴近耳朵通话,以便自动熄灭屏幕达到省电的目的。接近光传感器180G也可用于皮套模式,口袋模式自动解锁与锁屏。
环境光传感器180L用于感知环境光亮度。手机100可以根据感知的环境光亮度自适应调节显示屏194亮度。环境光传感器180L也可用于拍照时自动调节白平衡。环境光传感器180L还可以与接近光传感器180G配合,检测手机100是否在口袋里,以防误触。
指纹传感器180H用于采集指纹。手机100可以利用采集的指纹特性实现指纹解锁,访问应用锁,指纹拍照,指纹接听来电等。
温度传感器180J用于检测温度。在一些实施例中,手机100利用温度传感器180J检测的温度,执行温度处理策略。例如,当温度传感器180J上报的温度超过阈值,手机100执行降低位于温度传感器180J附近的处理器的性能,以便降低功耗实施热保护。在另一些实施例中,当温度低于另一阈值时,手机100对电池142加热,以避免低温导致手机100异常关机。在其他一些实施例中,当温度低于又一阈值时,手机100对电池142的输出电压执行升压,以避免低温导致的异常关机。
触摸传感器180K,也称“触控面板”。触摸传感器180K可以设置于显示屏194,由触摸传感器180K与显示屏194组成触摸屏,也称“触控屏”。触摸传感器180K用于检测作用于其上或附近的触摸操作。触摸传感器可以将检测到的触摸操作传递给应用处理器,以确定触摸事件类型。可以通过显示屏194提供与触摸操作相关的视觉输出。在另一些实施例中,触摸传感器180K也可以设置于手机100的表面,与显示屏194所处的位置不同。
骨传导传感器180M可以获取振动信号。在一些实施例中,骨传导传感器180M可以获取人体声部振动骨块的振动信号。骨传导传感器180M也可以接触人体脉搏,接收血压跳动信号。在一些实施例中,骨传导传感器180M也可以设置于耳机中,结合成骨传导耳机。音频模块170可以基于所述骨传导传感器180M获取的声部振动骨块的振动信号,解析出语音信号,实现语音功能。应用处理器可以基于所述骨传导传感器180M获取的血压跳动信号解析心率信息,实现心率检测功能。
按键190包括开机键,音量键等。按键190可以是机械按键。也可以是触摸式按键。手机100可以接收按键输入,产生与手机100的用户设置以及功能控制有关的键信号输入。
马达191可以产生振动提示。马达191可以用于来电振动提示,也可以用于触摸振动反馈。例如,作用于不同应用(例如拍照,音频播放等)的触摸操作,可以对应不同的振动反馈效果。作用于显示屏194不同区域的触摸操作,马达191也可对应不同的振动反馈效果。不同的应用场景(例如:时间提醒,接收信息,闹钟,游戏等)也可以对应不同的振动反馈效果。触摸振动反馈效果还可以支持自定义。
指示器192可以是指示灯,可以用于指示充电状态,电量变化,也可以用于指示消息,未接来电,通知等。
SIM卡接口195用于连接SIM卡。SIM卡可以通过插入SIM卡接口195,或从SIM卡接口195拔出,实现和手机100的接触和分离。手机100可以支持1个或N个SIM卡接口,N为大于1的正整数。SIM卡接口195可以支持Nano SIM卡,Micro SIM卡,SIM卡等。同一个SIM卡接口195可以同时插入多张卡。所述多张卡的类型可以相同,也可以不同。SIM卡接口195也可以兼容不同类型的SIM卡。SIM卡接口195也可以兼容外部存储卡。手机100通过SIM卡和网络交互,实现通话以及数据通信等功能。在一些实施例中,手机100采用eSIM,即:嵌入式SIM卡。eSIM卡可以嵌在手机100中,不能和手机100分离。
电子设备100的软件系统可以采用分层架构,事件驱动架构,微核架构,微服务架构,或云架构。本发明实施例以分层架构的Android系统为例,示例性说明电子设备100的软件结构。
图2是本发明实施例的手机100的软件结构框图。
分层架构将软件分成若干个层,每一层都有清晰的角色和分工。层与层之间通过软件接口通信。在一些实施例中,将Android系统分为四层,从上至下分别为应用程序层,应用程序框架层,安卓运行时(Android runtime)和系统库,以及内核层。
应用程序层可以包括一系列应用程序包。
如图2所示,应用程序包可以包括相机,图库,日历,通话,地图,导航,WLAN,蓝牙,音乐,华为视频,聊天等应用程序。
应用程序框架层为应用程序层的应用程序提供应用编程接口(ApplicationProgramming Interface,API)和编程框架,包括各种组件和服务来支持开发者的安卓开发。应用程序框架层包括一些预先定义的函数。如图2所示,应用程序框架层可包括视图系统、窗口管理器、资源管理器、内容提供器、系统服务等。视图系统包括可视控件,例如显示文字的控件,显示图片的控件等。视图系统可用于构建应用程序。显示界面可以由一个或多个视图组成的。窗口管理器用于管理窗口程序。窗口管理器可以获取显示屏大小,判断是否有状态栏,锁定屏幕,截取屏幕等。资源管理器为应用程序提供各种资源,比如本地化字符串,图标,图片,布局文件,视频文件等等。内容提供器用来存放和获取数据,并使这些数据可以被应用程序访问。所述数据可包括视频,图像,音频等。系统服务可用于根据应用的状态,进行前后台识别,以确定应用为前台应用或后台应用。其中,前台应用可选地为当应用对用户可见,并且用户可以与应用直接进行交互,例如,前台应用可以是用户正在进行键入操作的聊天应用,还可以是画中画应用,例如应用正在使用聊天应用时,可开启视频应用,视频窗口悬浮在聊天应用的应用界面上部,在该场景下,聊天应用与视频应用均属于前台应用。而正在运行且对用户不可见的应用,即为后台应用,例如,手机检测到用户的操作返回主页面后,聊天应用于视频应用均属于后台应用。
系统库与运行时层包括系统库和安卓运行时(Android Runtime)。系统库可以包括多个功能模块。例如:浏览器内核,3D图形库(例如:OpenGL ES),字体库等。浏览器内核负责对网页语法的解释(如标准通用标记语言下的一个应用HTML、JavaScript)并渲染(显示)网页。3D图形库用于实现三维图形绘图,图像渲染,合成和图层处理等。字体库用于实现不同字体的输入。安卓运行时包括核心库和虚拟机。安卓运行时负责安卓系统的调度和管理。核心库包含两部分:一部分是java语言需要调用的功能函数,另一部分是安卓的核心库。应用程序层和应用程序框架层运行在虚拟机中。虚拟机将应用程序层和应用程序框架层的java文件执行为二进制文件。虚拟机用于执行对象生命周期的管理,堆栈管理,线程管理,安全和异常的管理,以及垃圾回收等功能。
可以理解的是,图2示出的系统框架层、系统库与运行时层包含的部件,并不构成对手机100的具体限定。在本申请另一些实施例中,手机100可以包括比图示更多或更少的部件,或者组合某些部件,或者拆分某些部件,或者不同的部件布置。
内核层是硬件和软件之间的层。内核层至少包含显示驱动,摄像头驱动,音频驱动,传感器驱动、Cgroup(Control group,控制组)模块以及IO(input/output,输入/输出)子系统等。
下面结合图3对应用在读写过程中,系统服务、Cgroup模块以及IO子系统之间的交互进行具体说明,参照图3,具体的:
华为视频应用启动后,系统服务可实时监控华为视频应用的状态,并基于华为视频应用的状态,对华为视频应用进行前后台识别,以确定华为视频应用为前台应用或后台应用。示例性的,应用的状态包括但不限于:是否有用户触摸操作、是否在手机的显示窗口上显示等。举例说明,若手机的显示窗口包括主显示窗口和悬浮窗口,其中主显示窗口中显示的应用为聊天应用,悬浮窗口显示的应用为华为视频应用,并且,用户正在对聊天应用进行操作,在该场景下,华为视频应用与聊天应用均为前台应用。若手机的显示窗口中显示华为视频应用,则华为视频应用为前台应用。若显示窗口中未显示华为视频应用,且华为视频应用正在运行,则华为视频应用为后台应用,以上前/后台识别方式仅为示意性举例,本申请不做限定。系统服务还可以位于系统的其他层,本申请对此不做限定。检测应用处于前后台的方法还可以为其他,本申请对此不做限定。此处的前后台是以显示方式的作区分,还可以以其他方式区分前/后台应用,例如运行的前后台等(应用栈、程序标识等),本申请对此不做限定。
仍参照图3,示例性的,系统服务向Cgroup模块指示识别结果,CPU Cgroup模块可基于系统服务的识别结果,将应用置于对应的分组。示例性的,CPU Cgroup模块维护前台组和后台组,若系统服务指示将应用置于后台组,则CPU Cgroup根据系统服务的指示,将应用置于后台组。举例说明,CPU Cgroup可将应用的标识信息(以下简称为应用ID)写入后台组的上下文中,以表示该应用已置于后台组。可选地,应用ID可以是应用的应用程序包名称、进程名等,本申请不做限定。需要说明的是,本申请仅以系统服务与Cgroup模块之间的交互为例进行说明,在其他实施例中,系统服务还可以具有其它功能,本申请不再赘述。
上述内容均为CPU Cgroup模块对应用的管理流程,示例性的,对于IO Cgroup模块,其维护的是管控组与非管控组,也可以称为IO管控组和非IO管控组,示例性的,在应用启动后,系统服务向IO Cgroup模块指示应用启动,例如,向IO Cgroup模块输出该应用的应用ID。相应的,IO Cgroup模块可基于系统服务的指示,将应用置于默认分组,其中,默认分组为非管控组。举例说明,IO Cgroup模块可基于系统服务的指示,将应用ID写入非管控组的上下文中,以标识该应用置于非管控组。
示例性的,管控组与非管控组的上下文中除记录有组内的成员(即应用ID)之外,还分别记录有各自的管控策略,即,管控组的上下文中包含管控组对应的管控策略,非管控组的上下文中包含非管控组对应的管控策略。示例性的,管控组对应的管控策略包括但不限于管控组的读写速率上限(limit)值(也可以称为读写速率阈值或管控阈值),非管控组对应的管控策略为读写速率上限值为空,或者设置为0,即,IO管控模块不会对非管控组内的应用的读写速率进行管控,IO管控模块基于管控组与非管控组的管控策略对应用进行管控的具体方式将在下文中进行详细说明。
继续参照图3,仍以华为视频应用为例,示例性的,华为视频应用在启动后的任一时刻进行读写操作,其中,读写操作可选地为从存储中读取数据,和/或,向存储中写入数据。如图4所示为华为视频应用进行读写操作时的IO子系统中的各模块的交互示意图,参照图4,示例性的,华为视频应用与IO子系统进行交互,IO子系统可对华为视频应用的读写操作进行相应处理。具体的,IO子系统中包括但不限于:虚拟文件系统(Virtual filesystem,VFS)、文件系统和块层。其中,虚拟文件系统用于将其下的实体文件系统虚拟化,并向上层应用(例如华为视频应用)提供接口,以使上层应用可与文件系统进行数据交互。文件系统可以理解为一种存储和组织计算机数据的方法,文件系统使用文件和树形目录的抽象逻辑概念代替了物理设备(例如图4中的存储器)使用数据块的概念,用户可使用文件系统来保存数据,而不必关心数据实际保存在存储器中的具体位置。块层(Block Layer)用于接收并处理文件系统的IO请求队列,并进行IO调度处理。示例性的,当华为视频应用进行写入操作时,IO子系统基于华为视频应用的写入请求,依次通过虚拟文件系统、文件系统、块层,以写入硬件的存储器中。示例性的,当华为视频应用进行读取操作时,IO子系统基于华为视频应用的读取请求,从存储器中提取相应数据,并依次通过块层、文件系统、虚拟文件系统将数据输出至华为视频应用。需要说明的是,IO子系统可包括比图4中更少或更多的模块,本申请不做限定。可选地,IO子系统中还可以包括缓存模块(图中未示出),其中,缓存模块可以位于虚拟文件系统和/或文件系统中,也可以是与虚拟文件系统和文件系统分离的,示例性的,以缓存模块包含于文件系统为例,应用进行读写操作是的数据到达文件系统后,文件系统可将数据写入缓存模块,再通过缓存模块将数据写入块层。
参照图4,IO子系统中还包括后台高IO识别模块与IO管控模块,相应的,应用与IO子系统进行交互,以执行读写操作的过程中,后台高IO识别模块与IO管控模块可对应用的读写操作进行监控与管理。
下面结合具体场景对本申请实施例中后台高IO识别模块与IO管控模块对应用的读写操作进行监控与管理的具体流程进行详细说明。如图5所示为用户界面示意图,参照图5(1),示例性的,手机的主页面上可包括一个或多个控件,例如应用图标、电量图标、网络图标等,用户可点击“华为视频”应用的图标,手机检测到用户的点击操作,在显示窗口上显示“华为视频”应用的应用界面,如图5(2)所示,参照图5(2),示例性的,“华为视频”应用界面可包括一个或多个控件,例如视频显示窗口、媒体标题、选集选项、下载选项、评论选项等。用户可点击“下载”选项,手机检测到用户的点击操作,在显示窗口显示集数(例如电视剧的剧集数)以及“全选”选项和“查看我的缓存”选项,如图5(3)所示,参照图5(3),示例性的,用户可点击对应的集数,手机检测到用户的点击操作,从“华为视频”应用对应的服务器下载对应的集数(例如第5集),用户可点击“查看我的缓存”选项,以查看当前正在缓存(即下载)的进程,参照图5(4),示例性的,手机检测到用户的点击操作,在显示窗口显示“我的缓存”界面,该界面包括一个或多个控件,例如包括正在缓存的集数的进度显示条等。
如图6所示为在图5所示的场景的基础上,华为视频应用读写的过程中,手机中的模块(包括应用层、系统服务、Cgroup模块以及IO子系统)的交互示意图,参照图6,示例性的,华为视频应用启动(即图5中(1)中所示)后,系统服务可基于用户操作(即是否有用户触摸操作等)、华为视频的显示状态(即是否在手机的显示窗口上显示)等对“华为视频”应用进行前/后台识别,以确定“华为视频”应用为前台应用或后台应用。示例性的,如图5中所示,用户对“华为视频”应用进行相应操作,并且,“华为视频”应用显示在手机的显示窗口上,相应的,系统服务确认“华为视频”应用为前台应用。
仍参照图6,系统服务确认“华为视频”应用为前台应用后,指示Cgroup模块中的CPU Cgroup模块将“华为视频”应用置于前台组中,CPU Cgroup模块响应于系统服务的指示,将“华为视频”应用置于前台组(即top-app组),如图7a所示为CPU Cgroup中的分组示意图,参照图7a,示例性的,后台组(即background)中包括地图应用、音乐应用等。需要说明的是,图7a以及下面的各附图中的各组中包含的应用名称及数量仅为示意性举例,本申请不做限定,下文中不再重复说明。进一步需要说明的是,如果“华为视频”应用一直为前台应用,则系统服务不再向CPU Cgroup模块重复指示,系统服务仅在“华为视频”应用从前台切换到后台,也就是说,仅在应用发生前/后台变换的时候,指示CPU Cgroup将“华为视频”应用置于对应的分组。
如图7b所示为IO Cgroup模块中的分组示意图,参照图7b,示例性的,如上文所述,系统服务无需对IO Cgroup模块中的应用分组进行管控,仅需要向IO Cgroup模块通知“华为视频”应用启动即可,IO Cgroup模块将“华为视频”应用置于默认分组中,可选地,默认分组为非管控组。参照图7b,示例性的,IO Cgroup模块维护的非管控组中包括但不限于“华为视频”应用、地图应用、音乐应用等。
仍参照图6,示例性的,“华为视频”应用启动后,可选地进行读写操作,华为视频应用向存储读取或写入数据的过程可参照图4,此处不再赘述。示例性的,后台高IO识别模块基于华为视频应用的应用ID,从CPU Cgroup模块获取到华为视频应用为前台应用(如图7a所示),则后台高IO识别模块不做其它处理。举例说明,后台高IO识别模块可向CPU Cgroup模块输出华为视频应用的应用ID,以请求查询该应用ID所属的组。相应的,CPU Cgroup模块可基于应用ID,与前台组的上下文中包含的一个或多个应用的ID,以及后台组的上下文中包含的一个或多个应用ID进行匹配,并提取匹配成功的应用ID所属的组,示例性的,CPUCgroup模块基于应用ID,确定该应用ID所属的组为前台组,并向后台高IO识别模块输出查询结果,后台高IO识别模块可基于CPU Cgroup模块反馈的查询结果,确定应用ID对应的华为视频应用在前台组中,即华为视频应用为前台应用。
在图5所示的场景的基础上,如图8a所示为用户的操作示意图,参照图8a中的(1),示例性的,用户的手指在华为视频应用的“我的缓存”界面中从底端向上滑动,手机响应于用户的操作,在显示窗口上显示主页面,如图8a中的(2)所示,参照图8a中的(2),用户点击主页面中的聊天应用图标,手机响应于用户的操作,在显示窗口上显示聊天应用的界面,用户可在聊天应用的界面中键入信息。
需要说明的是,在用户使用聊天应用的过程中,华为视频应用仍然在运行,且正在下载选中的视频。举例说明,参照图8b中的(1),用户可在聊天应用的界面中从底端向上滑动并停止,手机响应于用户的操作,在显示窗口上显示多任务界面,其中,多任务界面中包括一个或多个窗口和控件,可选地,一个或多个控件可以包括但不限于清空图标,用户点击该清空图标后,手机响应于用户的操作可关闭当前正在运行的所有应用。可选地,一个或多个窗口显示当前正在运行的应用,包括前台应用和/或后台应用。示例性的,参照图8b中的(2),多任务界面中的其中一个窗口显示“我的缓存”界面对应的缩小界面,另一个窗口显示“聊天”界面对应的缩小界面,图8b可以理解为,用户在聊天应用的界面中进行相应操作,例如键入文字操作,华为视频应用仍然在后台运行。
结合图8a所示的场景,如图9所示为各模块的交互示意图,参照图9,示例性的,在图8a中的(1)所示的操作后,华为视频应用转入后台进行下载(即读写操作),系统服务基于华为视频应用当前的状态(即没有用户操作,且未在显示窗口中显示)确定华为视频应用为后台应用。相应的,系统服务指示Cgroup模块中的CPU Cgroup模块将华为视频应用置于background组(即后台组)中,CPU Cgroup模块响应于系统服务的指示将华为视频应用置于background组,例如,CPU Cgroup模块将华为视频应用的应用ID从top-app组(即前台组)对应的上下中删除,并写入background组对应的上下文中。
如图10所示为CPU cgourp模块的分组情况,参照图10,CPU Cgroup模块基于系统服务的指示,将聊天应用置于前台组,将华为视频应用置于后台组,后台组中还包括其它应用,例如地图应用、音乐应用等。
示例性的,IO Cgroup模块维护的IO分组仍然可参照图7b中所示的分组情况,此处不再赘述。
需要说明的是,下面的实施例中仅对后台应用的处理进行说明,对于前台应用,例如聊天应用,后台高IO识别模块在检测到聊天应用的读写操作后,确定该应用为前台应用,则不进行处理,该过程与上文所述华为视频应用为前台应用的场景中的步骤相同,此处不赘述。
下面结合图8a所示的场景对后台IO识别模块的处理流程进行详细说明,具体的,结合图9,华为视频应用与IO子系统进行交互,以执行读写操作的过程中,后台高IO识别模块可检测到华为视频应用对应有读写操作,后台高IO识别模块检测华为视频应用是否为后台应用。
示例性的,结合图10,后台高IO识别模块可从CPU Cgroup模块获取到华为视频应用位于background组,即华为视频应用为后台应用。可选地,如上文所述,若后台高IO识别模块检测到华为视频应用为前台应用,则后台高IO识别模块不作处理。
具体的,在本申请的实施例中,后台高IO识别模块确定华为视频应用为后台应用后,后台高IO识别模块检测是否需要对IO时间戳及华为视频应用的应用时间戳进行更新。
下面结合具体示例对IO时间戳与应用时间戳的相关概念及更新过程进行详细说明,如图11为示例性示出的IO时间戳、应用时间戳以及参考时间轴的示意图,参照图11,示例性的,参考时间轴为系统维护的时间轴,在本申请实施例中,参考时间轴的初始时刻0为手机开机的时刻,在其他实施例中,参考时间轴的初始时刻可以为手机开机后,系统初始化后完成时刻,还可以为手机第一次执行读写(是指开机后的任一应用触发的读写操作)的时刻,需要说明的是,参考时间轴上的各时刻实际上可以理解为相对时间,相对时间的起始时刻可以为开机时刻至第一次读写操作之间的任一时刻,本申请不做限定。
示例性的,在手机开机后,后台高IO识别模块未检测到任一后台应用的读写操作,则不生成IO时间戳。示例性的,参照图11,在1.5s,华为视频应用在后台开始进行读写操作,可以理解为,图8a中的(1)对应的操作时在开机后的1.5s执行的。需要说明的是,图11以及下面的附图中所示的各时刻仅为更好的说明时间戳之间的关系的示意性举例,其各时刻与实际使用中的时刻之间相差较大,例如,通常情况下,手机在开机后需要等待一定的响应时间(例如20s)后,用户才能启动华为视频应用,例如,在参考时间轴到达100s后,华为视频应用响应于用户操作开始进行读写操作,图11中所示的华为视频应用在开机后的1.5s开始在后台进行读写操作仅为示意性举例,本申请不做限定。
参照图11,华为视频应用在1.5s开始在后台进行读写操作,后台高IO识别模块检测到华为视频应用正在进行读写操作,并进一步检测到华为视频应用为后台应用(具体检测过程可参照图9中的描述)后,后台高IO识别模块检测当前的IO时间戳与当前的参考时间是否一致。示例性的,由于手机在开机后至当前时刻,即0~1.5s之间未存在后台应用读写,因此,后台高IO识别模块未记录IO时间戳。可选地,后台高IO识别模块也可以在开机后将IO时间戳设置为0,本申请不做限定。需要说明的是,在0~1.5s虽然存在华为视频应用的前台读写,后台IO识别模块未识别到后台应用读写,不对IO时间戳进行更新。
示例性的,仍参照图11,后台高IO识别模块检测到当前的IO时间戳(例如IO时间戳为0s)与当前的参考时间(即1.5s)不一致,后台高IO识别模块确定需要更新IO时间戳T,更新后的IO时间戳与当前的参考时间(即1.5s)一致,即T0=1.5s。
示例性的,在华为视频应用启动后,系统为其生成的进程上下文中包括应用时间戳,初始的应用时间戳t为t0=0s,即如图11中所示。后台高IO识别模块在1.5s,获取华为视频应用的应用时间戳t(t0=0s),接着,后台高IO识别模块将华为视频应用的应用时间戳t(t0=0s)与当前的IO时间戳T(T0=1.5s)进行比较,示例性的,在本实施例中,后台高IO识别模块判定应用时间戳t(t0=0s)与当前的IO时间戳T(T0=1.5s)不一致,后台高IO识别模块执行下述步骤:
1)后台高IO识别模块将华为视频应用的读写总量置为0。
2)后台高IO识别模块记录华为视频应用的本次读写量,并获取华为视频应用的读写速率。
3)后台高IO识别模块更新华为视频应用的应用时间戳。
示例性的,若内存中存储的华为视频应用的进程上下文中记录有对应于华为视频应用的读写量,则后台高IO识别模块将华为视频应用的进程上下文中记录的读写量置零,需要说明的是,由于本示例中是以华为视频应用在开机后进行第一次读写为例说明的,因此,华为视频应用的上下文中可能不存在对应的读写量,若存在对应的读写量(例如可能是上次开机过程中存储的)则将读写量置零。
需要说明的是,上述三个步骤(即1)~3))的顺序不分先后,本申请实施例中所述的上述步骤的顺序仅为示意性举例,本申请不做限定。
下面以具体示例对上述步骤进行详细说明。示例性的,参照图12,华为视频应用与IO子系统进行交互,以执行读写操作,具体读写操作可参照上文,此处不赘述。示例性的,后台高IO识别模块可获取到华为视频应用本次的读写量,例如本次读写量为4096Bytes(字节),后台高IO识别模块记录华为视频应用单次读写量。举例说明,参照图12,后台高IO识别模块将华为视频应用的单次读写量(4096Bytes)写入内存中存储的华为视频应用的进程上下文中。
示例性的,后台高IO识别模块可基于华为视频应用的读写总量,获取华为视频应用的读写速率。举例说明,后台高IO识别模块可基于下述公式得到应用的读写速率:
示例性的,在本申请中,IO时间戳更新周期设置为1s,在其他实施例中,也可以设置为其它数值,例如2s等,本申请不做限定。读写总量即为内存中存储的应用的进程上下文中记录的多个单次读写量的总和。
示例性的,在1.5s,华为视频应用进行一次读写,读写量为4096Bytes,后台高IO识别模块写入到内存中后,读取华为视频应用的进程上下文中记录的读写量总和,如上文所述,华为视频应用仅进行了一次读写,因此,华为视频应用的读写总量为第一次读写的读写量,即4096Byes,后台高IO识别模块基于上述公式,获取华为视频应用的读写速率为4096Bytes/s(字节/秒)。
示例性的,在本申请的实施例中,后台高IO识别模块可维护读写列表,可选地,读写列表可存储于内存中。示例性的,读写列表中记录有各后台应用对应的读写速率。举例说明,假设当前仅有华为视频应用进行了一次读写(不包括前台应用的读写),读写列表中包括华为视频应用的应用ID以及对应读写速率,示例性的,读写列表如表1所示:
表1
序号 | 应用ID | 读写速率 |
1 | 华为视频应用 | 4096Bytes/s |
其中,读写列表中的序号列表示对应的后台应用的读写速率的排行,示例性的,读写列表中按照各后台应用的读写速率从大到小依次排序,序号为1,即位于读写列表首位的后台应用的读写速率为当前读写速率最大的后台应用,具体示例将在下面的实施例中进行详细说明。
需要说明的是,本申请实施例中所述的读写列表的记录方式仅为示意性举例,后台高IO识别模块还可以以其它方式记录各后台应用的读写速率,本申请不做限定。
参照图13,示例性的,华为视频应用在1.5s~2.2s之间进行了n次读写操作,华为视频应用每执行一次读写操作,后台高IO识别模块对其进行上述步骤,即包括:检测华为视频应用是否为后台应用,进一步检测IO时间戳和华为视频应用的时间戳是否需要更新。在后台高IO识别模块检测到华为视频应用为后台应用,并且IO时间戳与华为视频应用的时间戳无需更新后,后台高IO识别模块记录华为视频应用的单次读写量,并获取华为视频应用的读写速率。需要说明的是,在上述n次读写过程中,也就是说1.5s~2.2s之间,由于T0(即1.5s)与每次读写的参考时间之间的差值未超过1s,因此,1.5s~2.2s之间,IO时间戳一直为T0=1.5s。也可以理解为,后台高IO识别模块只需要在1.5s时记录IO时间戳为T0=1.5s,随后,每次有应用进行读写,后台高IO识别模块均会将读写操作对应的参考时间与当前记录的IO时间戳(例如T0=1.5s)进行比较,若两者之间的时间差大于或等于1s,则说明到达IO时间戳更新时刻,具体更新步骤将在下面的实施例中进行详细说明。相应的,各应用的应用时间戳同理,即后台高IO识别模块仅在应用时间戳更新的时候记录一次该应用的应用时间戳,即,向应用的进程上下文中写入应用时间戳,随后,在每次应用读写时,后台高IO识别模块可基于当前记录的应用时间戳与IO时间戳进行比较,若两者不同,则更新应用时间戳,具体更新过程将在下面的实施例中说明。也就是说,IO时间戳与应用时间戳在本次更新至下一次更新之前的时间里,一直保持不变,下文中不再赘述。
仍参照图12,示例性的,后台高IO识别模块将1.5s~2.2s之间的n次读写中的各单次读写量写入到内存中存储的华为视频应用的进程上下文中。
如上文所述,后台高IO识别模块在每次记录华为视频应用的单次读写量后,获取华为视频应用的读写速率,读写速率的获取方式可参照上文,此处不再赘述。示例性的,后台高IO识别模块每获取一次华为视频应用的读写速率后,基于当前各后台应用的读写速率,更新读写列表。举例说明,后台高IO识别模块将华为视频应用在2.2s的读写量(4096Bytes)写入到华为视频应用的进程上下文后,后台高IO识别模块获取华为视频应用的进程上下文中记录的多个单次读写量之和,即为华为视频应用当前的读写总量,例如为30MB,后台高IO识别模块可基于上述公式,获取华为视频应用当前的读写速率为30MB/s,后台高IO识别模块可基于读写列表中记录的各应用的读写速率,更新读写列表,如表2所示为更新后的读写列表:
表2
需要说明的是,本申请仅以华为视频应用为例进行说明,表2中的音乐应用与地图应用在后台进行读写操作时,后台高IO识别模块对上述应用的处理方式与华为视频应用相同,表2中仅示出后台高IO识别模块基于音乐应用于地图应用进行读写操作后的结果,以更好得说明本申请的技术方案。
参照图14,示例性的,假设华为视频应用在2.2s进行读写后,停止读写,并在2.7s再次开始读写,其中,在2.2s之后也没有其它后台应用进行读写。后台高IO识别模块在检测到当前读写的华为视频应用为后台应用后,检测是否需要更新IO时间戳和华为视频应用的应用时间戳。
示例性的,参照图14,后台高IO识别模块获取当前的参考时间(即2.7s)以及IO时间戳(T0=1.5s),在本申请实施例中,均以IO时间戳更新周期为1s为例,后台高IO识别模块获取当前的参考时间与IO时间戳的差值(即为1.2s),该差值大于IO时间戳更新周期。相应的,后台高IO识别模块更新IO时间戳,更新后的IO时间戳T与当前的参考时间一致,即为T1=2.7s。以及,后台高IO识别模块按照图15执行如下步骤:
S101,后台高IO识别模块获取华为视频应用的读写速率。
示例性的,后台高IO识别模块更新IO时间戳后,后台高IO识别模块获取华为视频应用的读写速率。举例说明,后台高IO识别模块从内存存储的华为视频应用的进程上下文中读取多个单次读写量,并获取单次读写量之和,如图12所示,后台高IO识别模块获取到华为视频应用的读写速率为30MB/s,具体获取方式可参照上文,此处不赘述。
S102,后台高IO识别模块基于各后台应用的读写速率,判断是否存在满足管控条件的后台应用。
示例性的,后台高IO识别模块获取到华为视频应用的读写速率后,基于各后台应用的读写速率,更新读写列表,更新后的读写列表如表3所示:
表3
序号 | 应用ID | 读写速率 |
1 | 音乐应用 | 40MB/s |
2 | 华为视频应用 | 30MB/s |
3 | 地图应用 | 5MB/s |
…… |
示例性的,音乐应用在IO时间戳更新之前,其同样进行多次读写操作,在IO时间戳更新前,后台高IO识别模块最后一次获取到的音乐应用的读写速率为40MB/s。如上文所述,读写列表中按照各后台应用对应的读写速率,从大到小依次排列。
示例性的,后台高IO识别模块可基于各后台应用的读写速率,确定各后台应用是否满足管控条件。
可选地,管控条件包括但不限于:
1)读写速率为TOPN中的一个,其中,N为大于或等于1的整数。
2)读写速率大于阈值。
其中,TOPN即为后台应用在读写列表中的序号,假设N为3,若华为视频应用的读写速率为各后台应用的前3个速率,也就是说,华为视频应用在读写列表中的从上至下的前3个应用中,则华为视频应用满足管控条件1)。
仍以华为视频应用为例,后台高IO识别模块进一步检测到华为视频应用的读写速率是否大于阈值(例如50MB/s),若华为视频应用的读写速率大于50MB/s,则后台高IO识别模块确定后台应用满足管控条件2)。需要说明的是,对于管控条件1)和管控条件2)的判断顺序,后台高IO识别模块可以先判断后台应用是否满足管控条件1),并在满足管控条件1)的情况下,判断是否满足管控条件2),或者,后台高IO识别模块可以先判断后台应用是否满足管控条件2),并在满足管控条件2)的情况下,判断是否满足管控条件1),本申请不做限定。
需要说明的是,N的数值与阈值的设置可根据电子设备的IO能力进行设置,举例说明:手机的IO读写能力上限为100MB/s,若设置N为2,则所述阈值为50MB/s(即读写能力上限值除以N),上述计算方式仅为示意性举例,本申请不做限定。
示例性的,在本实施例中,后台高IO识别模块判定各后台应用(包括华为视频应用、音乐应用和地图应用等)均不满足管控条件,执行S103。
S103,后台高IO识别模块将各后台应用的读写总量置为0。
示例性的,仍以华为视频应用为例,后台高IO识别模块将内存存储的华为视频应用对应的进程上下文中的多个读写量清空,即实现将华为视频应用的读写总量置0。后台IO识别模块依次对各后台应用的读写总量执行清零操作。
示例性的,后台高IO识别模块将读写列表清空。
S104,后台高IO识别模块记录华为视频应用的本次读写量,并获取华为视频应用的读写速率。
示例性的,参照图16,华为视频应用通过IO子系统与存储进行数据交互,并且,后台高IO识别模块获取华为视频应用的本次读写量(例如4096Bytes),并将华为视频应用的读写量写入华为视频应用的进程上下文中。
S105,后台高IO识别模块更新华为视频应用的应用时间戳。
示例性的,仍参照图14,后台高IO识别模块更新华为视频应用的应用时间戳,更新后的华为视频应用的应用时间戳t与当前的IO时间戳T(T1=2.7s)一致,即应用时间戳t更新为t2=T1=2.7s。
可选地,华为视频应用可执行多次读写操作,对于华为视频应用的每次读写操作,后台高IO识别模块均执行检测是否为后台应用、检测是否需要更新IO时间戳和应用时间戳等操作,并且,后台高IO识别模块将华为视频应用每次读写的读写量写入华为视频应用的进程上下文中,如图16所示,后台IO识别模块还可用于执行基于各后台应用的读写总量,更新读写列表等操作,具体步骤可参照上文,此处不再赘述。
在一种可能的实现方式中,假设音乐应用在后台的最后一次读写是在参考时间为2.7s之前发生的(例如2.6s发生的),参照图14,示例性的,音乐应用在2.9s进行读写操作,后台高IO识别模块检测到音乐应用为后台应用,并且,当前的参考时间(即2.9s)与IO时间戳T(T=2.7s)之间的时间差(即0.2s)小于IO时间戳更新周期,后台高IO识别模块判定无需对IO时间戳进行更新。进一步的,后台高IO识别模块将音乐应用的应用时间戳t(例如t1=1.5s)与当前的IO时间戳T(T=2.7s)进行比较,后台高IO识别模块判定音乐应用的应用时间戳t(例如t1=1.5s)与当前的IO时间戳T(T=2.7s)不一致,后台高IO识别模块将音乐应用的应用时间戳进行更新,更新后的应用时间戳与当前的IO时间戳一致,即更新后的音乐应用的应用时间戳t表示为t2=T1=2.7s。并且,后台高IO识别模块记录音乐应用的读写量,并获取音乐应用对应的读写速率,基于音乐应用的读写速率更新读写列表。具体细节可参照S104和S105中的相关描述,此处不赘述。可以理解为,无需对IO时间戳更新的情况下,后台高IO识别模块仅对各应用执行获取读写速率,并更新读写列表的操作,或者,执行获取读写速率并更新读写列表和更新应用时间戳的操作,其中,更新应用时间戳的操作仅在应用时间戳与IO时间戳不一致的情况下执行。
示例性的,参照图17,仍以华为视频应用为例,华为视频应用在3.8s进行读写操作,后台高IO识别模块检测到华为视频应用为后台应用后,进一步检测到当前的参考时间为3.8s,仍以IO时间戳更新周期为1s为例,后台高IO识别模块获取当前的IO时间戳T为T1=2.7s,其与当前的参考时间(3.8s)之间的时间差为1.2s,该时间差大于IO时间戳更新周期(1s),则后台高IO识别模块更新IO时间戳,更新后的IO时间戳T与当前的参考时间一致,即为T2=3.8s。以及,后台高IO识别模块按照图18执行如下步骤:
S201,后台高IO识别模块获取华为视频应用的读写速率。
后台高IO识别模块从内存存储的华为视频应用的进程上下文中读取多个单次读写量,并获取单次读写量之和,如图16所示,后台高IO识别模块获取到华为视频应用的读写速率为200MB/s,具体获取方式可参照上文,此处不赘述。
S202,后台高IO识别模块基于各后台应用的读写速率,判断是否存在满足管控条件的后台应用。
示例性的,后台高IO识别模块获取到华为视频应用的读写速率后,基于各后台应用的读写速率,更新读写列表,更新后的读写列表如表4所示:
表4
序号 | 应用ID | 读写速率 |
1 | 华为视频应用 | 200MB/s |
2 | 音乐应用 | 70MB/s |
3 | 地图应用 | 10MB/s |
…… |
示例性的,音乐应用在IO时间戳更新之前,其同样进行多次读写操作,在IO时间戳更新前(即3.8s前),后台高IO识别模块最后一次获取到的音乐应用的读写速率为70MB/s。如上文所述,读写列表中按照各后台应用对应的读写速率,从大到小依次排列。
示例性的,后台高IO识别模块可基于各后台应用的读写速率,确定各后台应用是否满足管控条件。在本实施例中,后台高IO识别模块确定音乐应用与华为视频应用均满足管控条件,管控条件可参照上文,此处不赘述。
S203,后台高IO识别模块指示IO Cgroup模块将音乐应用和华为视频应用置于管控组。
示例性的,参照图19,后台高IO识别模块确定音乐应用和华为视频应用满足管控条件后,后台高IO识别模块可指示Cgroup模块中的IO Cgroup模块将音乐应用和华为视频应用置于管控组。相应的,IO Cgroup模块响应于后台高IO识别模块的指示,将后台应用置于管控组。如图19所示,IO Cgroup模块维护的IO分组中,管控组包括华为视频应用和音乐应用,非管控组中包括聊天应用、地图应用等。
S204,后台高IO识别模块将各后台应用的读写总量置为0。
S205,后台高IO识别模块记录华为视频应用的本次读写量,并获取华为视频应用的读写速率。
S204~S205的具体步骤可参照S103~S104的相关步骤,此处不赘述。
S206,后台高IO识别模块更新华为视频应用的应用时间戳。
示例性的,仍参照图17,后台高IO识别模块更新华为视频应用的应用时间戳,更新后的华为视频应用的应用时间戳t与当前的IO时间戳T(T2=3.8s)一致,即应用时间戳t更新为t3=T2=3.8s。
需要说明的是,上文中均是以华为视频应用的读写触发IO时间戳更新为例进行说明的,实际上,在多个后台应用进行读写操作的过程中,任一应用在超过IO时间戳更新时刻后进行读写操作,均会触发后台高IO识别模块更新IO时间戳,并执行后续的应用时间戳更新以及管控条件判断等过程。
在一种可能的实现方式中,后台高IO识别模块确定后台应用(例如华为视频应用)满足管控条件后,后台高IO识别模块记录华为视频应用被置于后台组的时刻(例如3.8s)。示例性的,若在设定的时长内,华为视频应用未满足上述管控条件,则后台高IO识别模块指示IO Cgroup模块将华为视频应用置于非管控组,其中,在设定的时长内,即使华为视频应用未满足上述管控条件,后台高IO识别模块仍然将其置于管控组。可选地,设定的时长可以为IO更新时间戳周期的3倍时长,例如3s。
在另一种可能的实现方式中,若后台IO识别模块在设定的时长内(例如IO更新时间戳周期的3倍时长)未检测到任一后台应用读写,则在设定时长后的任一后台应用进行读写时,后台高IO识别模块检测到当前的IO时间戳与参考时间之间的时间差大于设定的时长,后台高IO识别模块对IO时间戳进行更新后,并按照上文所述的华为视频应用在开机后的初次后台读写的步骤执行,即,后台高IO识别模块仅对后台应用执行如下步骤:
1)后台高IO识别模块将各后台应用的读写总量置为0。
2)后台高IO识别模块记录后台应用的本次读写量,并获取后台应用的读写速率。
3)后台高IO识别模块更新后台应用的应用时间戳。
也就是说,在初次更新IO时间戳和设定的时长后更新时间戳的情况下,后台高IO识别模块不会对各后台应用进行管控条件的判断操作。
在另一种可能的实现方式中,后台高IO识别模块可配置有允许名单,允许名单中可包括一个或多个应用的应用ID。示例性的,后台高IO识别模块在检测到允许名单中的应用进行读写操作时,不对该应用进行处理。示例性的,后台高IO识别模块将进行读写操作的后台应用的应用ID于允许名单中的应用ID进行匹配,若匹配成功,则后台高IO识别模块不对该应用的本次读写操作进行处理。示例性的,允许名单中的应用在请求读写时,可携带特殊标识信息,后台高IO识别模块在识别到该特殊标识信息后,即可确定该应用为无需进行管控的应用。
在又一种可能的实现方式中,后台高IO识别模块可在每次IO时间戳更新周期到达时刻,更新IO时间戳,并执行管控条件判断等操作。举例说明,参照图20,在手机开机后,后台高IO识别模块在1.5s检测到后台应用(例如为音乐应用)进行读写操作,更新IO时间戳T为T0=1.5s。后台高IO识别模块可设置定时器,定时器的计时时长为1s,也就是说IO时间戳更新周期时长为1s,定时器每次计时技术,即到达IO时间戳更新周期,后台高IO识别模块更新IO时间戳,例如,在1.5s开始计时,在2.5s计时器结束计时,后台高IO识别模块将IO时间戳更新,更新后的IO时间戳与当前的参考时间一致,即为T1=2.5s。在IO时间戳更新时刻,仍按照上文所述的步骤执行,即判断后台应用是否符合管控条件等操作。仍参照图20,假设华为视频应用在3.3s开始读写(华为视频应用在后台),示例性的,后台高IO识别模块检测到华为视频应用的应用时间戳t(t0=0s)与当前的IO时间戳T(T1=2.5s)不一致,则后台高IO识别模块将华为视频应用的应用时间戳更新为与当前的IO时间戳一致,更新后的应用时间戳t为t1=T1=2.5s,接着,后台高IO识别模块执行获取华为视频应用的读写速率,更新读写列表等操作。未描述事宜与上文中的各步骤相同或相似,此处不再赘述。
下面对IO管控模块对应用的管控流程进行详细说明,参照图21,IO管控模块执行步骤包括:
S301,IO管控模块获取华为视频应用的读写量。
示例性的,与后台高IO识别模块类似,在华为视频应用进行读写操作时,IO管控模块同样可获取到华为视频应用的读写量及其应用ID,示例性的,以华为视频应用的本次读写量为4096Bytes为例。
S302,IO管控模块确定华为视频应用在管控组。
示例性的,参照图21,IO管控模块基于华为视频应用的应用ID,从IO Cgourp模块获取华为视频应用被置于管控组,具体查询方式可参照上文与CPU Cgroup模块的查询方式相同,此处不赘述。
S303,IO管控模块读取管控组的读写总量,获取管控组的读写速率。
示例性的,IO管控模块从内存中存储的管控组的上下文中,获取管控组对应的读写总量,例如,当前记录的管控组的读写总量为80MB。
需要说明的是,管控组的读写总量为管控组内所有应用(包括华为视频应用与音乐应用)在管控周期内的进行一次或多次读写的读写量之和。示例性的,管控周期为1s,举例说明,IO管控模块设置有定时器,定时器时长为1s,该定时时长即为管控周期,IO管控模块在每次定时器计时结束后,将管控组的上下文中的读写总量置0,并重新开始计时。
示例性的,IO管控模块可基于获取到的管控组的读写总量和华为视频应用的本次读写量,获取管控组对应的读写速率。举例说明,IO管控模块可基于下述公式计算管控组的读写速率:
例如,IO管控模块基于上述公式,计算出管控组当前的读写速率为81MB/s。
具体的,IO管控模块基于管控组的读写速率,判定管控组的读写速率是否超过读写阈值。示例性的,管控组的上下文中记录有管控组对应的读写阈值(也可以称为管控阈值),例如管控阈值为100MB/s。
一个示例中,IO管控模块基于管控组当前的读写速率(80MB/s),判定管控组当前的读写速率未超过管控组的管控阈值(100MB/s),IO管控模块确定无需对管控组中的应用进行管控,也就是说,IO管控模块允许华为视频应用进行读写操作,华为视频应用可执行读写操作,具体细节可参照上文,此处不赘述,IO管控模块执行S304。
另一个示例中,IO管控模块基于管控组当前的读写速率,例如当前的读写速率为103MB/s,IO管控模块将禁止管控组中的各应用进行读写操作,例如,IO管控模块禁止华为视频应用的本次读写以及其它在管控组中的应用(例如音乐应用)的读写操作。示例性的,以IO管控模块禁止华为视频应用的本次读写为例,IO管控模块指示块层禁止将华为视频应用本次读写的数据写入存储,例如,IO管控模块可以向块层发送华为视频应用的应用ID等方式,以向块层指示需要禁止进行读写的应用,如上文所述,应用的数据可通过文件系统的缓存模块向块层传输,并写入存储,示例性的,块层可基于IO管控模块的指示,拒绝缓存模块输入的数据,也就是说,不会将缓存模块输入的数据写入存储,也就是说,数据仍然存储在缓存中。示例性的,IO管控模块执行禁止读写操作后,启动定时器,定时器的计时时长可以为1s,也可以为其它数值,例如125ms,本申请不做限定。在定时器的计时时长结束后,IO管控模块将管控组的读写总量清空,并重新执行S301。需要说明的是,以华为视频应用为例,在IO管控模块禁止管控组内的应用读写后,华为视频应用的本次读写对应的数据以及后面在1s内获取到的数据将写在缓存中,并在IO管控模块的定时器计时结束后(即1s后)再将缓存中的数据写入存储。需要说明的是,若缓存模块可基于缓存的数据的大小,适应性释放缓存空间,可选地,若缓存模块释放空间失败,或可理解为缓存模块当前可用空间不足,此时,应用仍然在下载数据并执行读写过程,相应的,IO子系统可限制应用的下载速度,以缓解缓存模块的压力。
S304,IO管控模块记录华为视频应用的读写量。
示例性的,IO管控模块将华为视频应用本次的读写量(例如4096Bytes)写入管控组的上下文中。
在一种可能的实现方式中,IO管控模块可维护两个或两个以上管控组,不同的管控组对应的管控阈值不相同,例如管控组1对应的管控阈值为100MB/s,管控组2对应的管控阈值为200MB/s。示例性的,不同的管控组对应的管控条件也不相同,例如,读取列表中排在首位,且超过阈值(50MB/s)的后台应用置于管控组1,排在第二位和第三位,且超过阈值的后台应用置于管控组2。示例性的,管控条件也可以根据应用的类型等进行设置,本申请不做限定。
下面结合图22对管控组对应的管控阈值的获取方式进行详细说明,参照图22,示例性的,系统服务中设置有测试读写接口,系统服务在指定时刻调用测试读写接口与IO子系统进行交互,以执行读写操作。测试读写接口可获取到测试结果,例如测试结果为读写速率为100MB/s,系统服务预先配置有前台读写速率需求,该需求用于指示所有前台应用的读写速率上限值,例如为60MB/s,相应的,当测试结果为100MB/s时,管控组对应的管控阈值即为测试结果与前台应用的读写速率上限值之间的差值,例如40MB/s。测试读写接口将获取到的管控阈值输出至IO Cgroup模块,IO Cgroup模块可将管控阈值(40MB/s)写入管控组的上下文中。
可选地,所述指定时刻可选地为一个月或者一周,本申请不做限定。
需要说明的是,随着手机使用造成的硬件老化等问题,测试结果的可能会越来越小,例如,1年后获取到的测试结果为80MB/s,一个示例中,在所有前台应用的读写速率上限值不变,仍为60MB/s的情况下,管控组对应的管控阈值更新为20MB/s。另一个示例中,前台应用的读写速率上限值和后台的管控阈值可以按比例缩小,可选地,按比例缩小时,比例可以相同,也可以不同,在比例不同的情况下,后台应用的管控阈值对应的缩小比例小于前台应用的读写速率上限值的缩小比例。
进一步需要说明的是,根据各厂商所生产的硬件能力不同,不同的电子设备其对应的IO能力也不相同,相应的,基于不同硬件能力,本申请实施例中所涉及的各数值,例如管控条件中的TOPN和阈值、管控组对应的读写速率阈值等也不相同,本申请不做限定。
进一步需要说明的是,本申请实施例中均是以应用的读写速率为例,对应用进行监控与管理的,在其他实施例中,后台IO识别模块和IO管控模块还可以是基于应用的读写量等可以用于表示应用在单位时间内的读写量的信息,对应用进行监控与管理,本申请不做限定。
在一种可能的实现方式中,本申请上面的各场景中所述的“读写量”、“读写总量”等均是指应用进行“读”操作对应的量,也就是说,本申请中的电子设备可只对应用的“读”的量进行监控和管理,而无需对“写”操作进行监控和管理。
在另一种可能的实现方式中,本申请上面的各场景中所述的“读写量”、“读写总量”等均是指应用进行“写”操作的量,也就是说,本申请中的电子设备可只对应用的“写”的量进行监控和管理,而无需对“读”操作进行监控和管理。
在又一种可能的实现方式中,本申请上面的各场景中所述的“读写量”、“读写总量”等是指“读”和“写”操作的量,也就是说,本申请中的电子设备可对“读”和“写”操作进行监控和管理。一个示例中,以图12为例,后台高IO识别模块在记录每次读写量时,是将“读”的量或者“写”的量记录到应用进程上下文中,后台高IO识别模块读取读写量时,则是读取的“读”和“写”的总量,并获取“读”和“写”的总量之和,在监控的过程中,例如更新读写列表时,读写列表中记录的是每个应用对应的“读”和“写”的总量对应的速率,相应的,管控组的上下文中的管控策略,则是用于对“读”和“写”的总量进行管控,例如,若管控策略为读写速率阈值为100M/s,是指基于“读”和“写”的总量之和获取到的速率值小于100M/s,其它未描述内容均可参照上文中各场景实施例的相关内容,此处不再赘述。另一个示例中,仍以图12为例,后台高IO识别模块在记录每次读写量时,仍是将“读”的量或者“写”的量记录到应用进程上下文中,后台高IO识别模块读取读写量时,可分别读取“读”的总量和“写”的总量,其中,“读”的总量即为各单次“读”的量之和,“写”的总量即为各单次“写”的量之和。在监控的过程中,例如更新读写列表时,读写列表可以包括读写列表1和读写列表2,读写列表1用于记录各应用的“读”的总量对应的速率,读写列表2用于记录各应用的“写”的总量对应的速率,可选地,“读”和“写”的管控条件可以相同,也可以不同,本申请不做限定,后台高IO识别模块可基于“读”操作对应的管控条件和“写”操作对应的管控条件,对应用的“读”和“写”操作分别进行监控,以确定是否需要将应用放置管控组。相应的,管控组的上下文中可包括对应于“读”操作的管控策略和对应于“写”操作的管控策略,可选地,两个管控策略可以相同也可以不同,例如“读”操作的管控策略限制读写速率上限为100M/s,“写”操作的管控策略限制读写速率上限为200M/s,也就是说,在管控过程中,管控组内的各应用的“读”操作的总量之和对应的速率小于100M/s,“写操作”的总量置和对应的速率小于200M/s,举例说明,若管控组的各应用的“读”操作的总量之和对应的速率大于或等于100M/s,但是“写”操作的总量之和对应的速率小于200M/s,则只对“读”操作进行管控,例如,在1s内不允许管控组内的所有应用进行“读”操作,但是允许管控组内的应用进行“写”操作。
在又一种可能的实现方式中,后台高IO识别模块与IO管控模块可在设定的条件下才执行对电子设备中的后台应用进行监控与管理,一个示例中,后台高IO识别模块与IO管控模块在电子设备(例如手机)息屏后,可退出对应用的读写操作的监控与管理。例如,当手机息屏后,后台高IO识别模块停止相关的识别、判断等监控过程,并且,IO管控模块将管控组内的所有应用移出(即移入非管控组),或者,不再对管控组内的应用进行管控。另一个示例中,若电子设备中的未运行前台应用,例如,电子设备显示的是桌面(即主页面),后台高IO识别模块与IO管控模块可不对后台应用的读写操作进行监控与管理。又一个示例中,若电子设备中运行的所有应用的总读写量未超过设定的阈值,和/或,电子设备中在前台运行的应用的总读写量未超过设定的阈值,则后台高IO识别模块与IO管控模块可不对后台应用的读写操作进行管控与管理。举例说明,在用户使用手机玩游戏时,若游戏应用的读写量需求较低,即游戏应用的读写量小于设定的阈值,则电子设备可不对后台应用的读写操作进行管控,若游戏应用的读写量需求较高,例如其读写速率为80M/s,则电子设备对后台应用的读写操作进行管控,以使读写资源向前台应用(例如游戏应用)倾斜。
可以理解的是,电子设备为了实现上述功能,其包含了执行各个功能相应的硬件和/或软件模块。结合本文中所公开的实施例描述的各示例的算法步骤,本申请能够以硬件或硬件和计算机软件的结合形式来实现。某个功能究竟以硬件还是计算机软件驱动硬件的方式来执行,取决于技术方案的特定应用和设计约束条件。本领域技术人员可以结合实施例对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。
一个示例中,图23示出了本申请实施例的一种装置200的示意性框图装置200可包括:处理器201和收发器/收发管脚202,可选地,还包括存储器203。
装置200的各个组件通过总线204耦合在一起,其中总线204除包括数据总线之外,还包括电源总线、控制总线和状态信号总线。但是为了清楚说明起见,在图中将各种总线都称为总线204。
可选地,存储器203可以用于前述方法实施例中的指令。该处理器201可用于执行存储器203中的指令,并控制接收管脚接收信号,以及控制发送管脚发送信号。
装置200可以是上述方法实施例中的电子设备或电子设备的芯片。
其中,上述方法实施例涉及的各步骤的所有相关内容均可以援引到对应功能模块的功能描述,在此不再赘述。
本实施例还提供一种计算机存储介质,该计算机存储介质中存储有计算机指令,当该计算机指令在电子设备上运行时,使得电子设备执行上述相关方法步骤实现上述实施例中的管控方法。
本实施例还提供了一种计算机程序产品,当该计算机程序产品在计算机上运行时,使得计算机执行上述相关步骤,以实现上述实施例中的管控方法。
另外,本申请的实施例还提供一种装置,这个装置具体可以是芯片,组件或模块,该装置可包括相连的处理器和存储器;其中,存储器用于存储计算机执行指令,当装置运行时,处理器可执行存储器存储的计算机执行指令,以使芯片执行上述各方法实施例中的管控方法。
其中,本实施例提供的电子设备、计算机存储介质、计算机程序产品或芯片均用于执行上文所提供的对应的方法,因此,其所能达到的有益效果可参考上文所提供的对应的方法中的有益效果,此处不再赘述。
通过以上实施方式的描述,所属领域的技术人员可以了解到,为描述的方便和简洁,仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将装置的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。
在本申请所提供的几个实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个装置,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。
作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是一个物理单元或多个物理单元,即可以位于一个地方,或者也可以分布到多个不同地方。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本申请各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
本申请各个实施例的任意内容,以及同一实施例的任意内容,均可以自由组合。对上述内容的任意组合均在本申请的范围之内。
集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个可读取存储介质中。基于这样的理解,本申请实施例的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该软件产品存储在一个存储介质中,包括若干指令用以使得一个设备(可以是单片机,芯片等)或处理器(processor)执行本申请各个实施例方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(read only memory,ROM)、随机存取存储器(random access memory,RAM)、磁碟或者光盘等各种可以存储程序代码的介质。
上面结合附图对本申请的实施例进行了描述,但是本申请并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本申请的启示下,在不脱离本申请宗旨和权利要求所保护的范围情况下,还可做出很多形式,均属于本申请的保护之内。
结合本申请实施例公开内容所描述的方法或者算法的步骤可以硬件的方式来实现,也可以是由处理器执行软件指令的方式来实现。软件指令可以由相应的软件模块组成,软件模块可以被存放于随机存取存储器(Random Access Memory,RAM)、闪存、只读存储器(Read Only Memory,ROM)、可擦除可编程只读存储器(Erasable Programmable ROM,EPROM)、电可擦可编程只读存储器(Electrically EPROM,EEPROM)、寄存器、硬盘、移动硬盘、只读光盘(CD-ROM)或者本领域熟知的任何其它形式的存储介质中。一种示例性的存储介质耦合至处理器,从而使处理器能够从该存储介质读取信息,且可向该存储介质写入信息。当然,存储介质也可以是处理器的组成部分。处理器和存储介质可以位于ASIC中。另外,该ASIC可以位于网络设备中。当然,处理器和存储介质也可以作为分立组件存在于网络设备中。
本领域技术人员应该可以意识到,在上述一个或多个示例中,本申请实施例所描述的功能可以用硬件、软件、固件或它们的任意组合来实现。当使用软件实现时,可以将这些功能存储在计算机可读介质中或者作为计算机可读介质上的一个或多个指令或代码进行传输。计算机可读介质包括计算机存储介质和通信介质,其中通信介质包括便于从一个地方向另一个地方传送计算机程序的任何介质。存储介质可以是通用或专用计算机能够存取的任何可用介质。
上面结合附图对本申请的实施例进行了描述,但是本申请并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本申请的启示下,在不脱离本申请宗旨和权利要求所保护的范围情况下,还可做出很多形式,均属于本申请的保护之内。
Claims (24)
1.一种管控方法,其特征在于,包括:
在第一电子设备上的后台运行第一应用的过程中,获取所述第一应用在第一周期内的第一读写总量;
基于所述第一读写总量,判断所述第一应用是否满足设定的管控条件;
当所述第一应用满足所述管控条件时,对所述第一应用在第二周期内的读写操作进行管控,管控后的所述第一应用在所述第二周期内的第二读写总量小于管控阈值。
2.根据权利要求1所述的方法,其特征在于,所述第一周期与所述第二周期为相邻周期,所述第一周期与所述第二周期的时长相同或不同。
3.根据权利要求1所述的方法,其特征在于,所述管控条件包括以下至少之一:
所述第一读写总量为已获取的多个应用的读写总量前N个最大的读写总量中的一个,所述N为大于或等于1的整数,所述多个应用的读写总量为在所述第一周期内获取到的;
所述第一读写总量大于或等于第一阈值。
4.根据权利要求1所述的方法,其特征在于,所述对所述第一应用在第二周期内的读写操作进行管控,包括:
当所述第一应用在所述第二周期内进行第一读写操作,获取所述第一应用在所述第二周期时间内的第二读写总量;其中,所述第一读写操作对应的读写量为第三读写量;
当所述第三读写量与所述第二读写总量之和大于或等于所述管控阈值,将所述第一读写操作对应的数据输入至缓存中;
当所述第三读写量与所述第二读写总量之和小于所述管控阈值,将所述第一读写操作对应的数据输入至缓存中,并通过所述缓存将数据写入存储中。
5.根据权利要求1所述的方法,其特征在于,在第一电子设备上的后台运行第一应用的过程中,所述第一电子设备还在后台运行第二应用,所述方法还包括:
获取所述第二应用在所述第一周期内的第三读写总量;
基于所述第三读写总量,判断所述第二应用是否满足所述管控条件;
若所述第二应用满足所述管控条件,对所述第二应用在所述第二周期内的读写操作进行管控,管控后的所述第二应用在所述第二周期内的第四读写总量与所述第二读写总量之和小于所述管控阈值。
6.根据权利要求5所述的方法,其特征在于,所述对所述第二应用在所述第二周期内的读写操作进行管控,包括:
当所述第一应用进行第一读写操作,获取所述第一应用在所述第二周期内的第二读写总量以及所述第二应用在所述第二周期内的第四读写总量;其中,所述第一读写操作对应的读写量为第三读写量;
当所述第三读写量、所述第二读写总量与所述第四读写总量之和大于或等于所述管控阈值,在所述第二周期时间内将所述第一应用的第一读写操作对应的数据写入缓存中,以及,在所述第二周期内将所述第二应用的读写操作对应的数据写入所述缓存中;
当所述第三读写量、所述第二读写总量与所述第四读写总量之和大于或等于所述管控阈值,将所述第一读写操作对应的数据输入至缓存中,并通过所述缓存将数据写入存储中,以及,在所述第二周期内将所述第二应用的读写操作对应的数据输入至缓存中,并通过所述缓存将数据写入存储中。
7.根据权利要求1至6任一项所述的方法,其特征在于,所述方法还包括:
按照设定的触发条件,更新所述管控阈值。
8.根据权利要求1所述的方法,其特征在于,在第一电子设备上的后台运行第一应用的过程中,所述第一电子设备还运行第三应用,所述方法还包括:
获取所述第三应用在所述第一周期内的第五读写总量,所述第五读写总量小于所述第一读写总量;
基于所述第五读写总量,判定所述第三应用不满足所述管控条件,确定不需要对所述第三应用在所述第二周期内的读写操作进行所述管控。
9.根据权利要求1所述的方法,其特征在于,所述获取所述第一应用在第一周期内的第一读写总量,包括:
获取所述第一应用在所述第一周期内的多次读写操作中每次读写操作对应的读写量;
获取每次读写操作对应的读写量之和,所述读写量之和为所述第一读写总量。
10.根据权利要求9所述的方法,其特征在于,所述获取所述第一应用在第一周期内的第一读写总量,包括:
在所述第一应用在所述第一周期内进行第一次读写操作时,设置第一输入输出IO时间戳;
在所述第一应用进行第M次读写操作时,检测所述第M次读写操作对应的时刻与所述IO时间戳之间的相对时长是否大于或等于所述第一周期的周期时长;其中,M为大于1的整数;
当所述相对时长大于或等于所述第一周期的周期时长,获取所述第一应用在所述第一周期内的第一读写总量,所述第一读写总量为M次读写操作对应的读写量之和。
11.根据权利要求1所述的方法,其特征在于,若满足下述条件中的至少一个,获取所述第一应用在第一周期内的第一读写总量:
所述第一电子设备为非息屏状态;
所述第一电子设备在前台运行一个或多个应用;
所述第一电子设备中运行的各应用的读写总量大于第一阈值;
所述一个或多个应用的读写总量大于第二阈值。
12.一种电子设备,其特征在于,包括:
一个或多个处理器;
存储器;
以及一个或多个计算机程序,其中所述一个或多个计算机程序存储在所述存储器上,当所述计算机程序被所述一个或多个处理器执行时,使得所述电子设备执行以下步骤:
在所述电子设备上的后台运行第一应用的过程中,获取所述第一应用在第一周期内的第一读写总量;
基于所述第一读写总量,判断所述第一应用是否满足设定的管控条件;
当所述第一应用满足所述管控条件时,对所述第一应用在第二周期内的读写操作进行管控,管控后的所述第一应用在所述第二周期内的第二读写总量小于管控阈值。
13.根据权利要求12所述的设备,其特征在于,所述第一周期与所述第二周期为相邻周期,所述第一周期与所述第二周期的时长相同或不同。
14.根据权利要求12所述的设备,其特征在于,所述管控条件包括以下至少之一:
所述第一读写总量为已获取的多个应用的读写总量前N个最大的读写总量中的一个,所述N为大于或等于1的整数,所述多个应用的读写总量为在所述第一周期内获取到的;
所述第一读写总量大于或等于第一阈值。
15.根据权利要求12所述的设备,其特征在于,当所述计算机程序被所述一个或多个处理器执行时,使得所述电子设备执行以下步骤:
当所述第一应用在所述第二周期内进行第一读写操作,获取所述第一应用在所述第二周期时间内的第二读写总量;其中,所述第一读写操作对应的读写量为第三读写量;
当所述第三读写量与所述第二读写总量之和大于或等于所述管控阈值,将所述第一读写操作对应的数据输入至缓存中;
当所述第三读写量与所述第二读写总量之和小于所述管控阈值,将所述第一读写操作对应的数据输入至缓存中,并通过所述缓存将数据写入存储中。
16.根据权利要求12所述的设备,其特征在于,在所述电子设备上的后台运行第一应用的过程中,所述所述电子设备还在后台运行第二应用,当所述计算机程序被所述一个或多个处理器执行时,使得所述电子设备执行以下步骤:
获取所述第二应用在所述第一周期内的第三读写总量;
基于所述第三读写总量,判断所述第二应用是否满足所述管控条件;
若所述第二应用满足所述管控条件,对所述第二应用在所述第二周期内的读写操作进行管控,管控后的所述第二应用在所述第二周期内的第四读写总量与所述第二读写总量之和小于所述管控阈值。
17.根据权利要求16所述的设备,其特征在于当所述计算机程序被所述一个或多个处理器执行时,使得所述电子设备执行以下步骤:
当所述第一应用进行第一读写操作,获取所述第一应用在所述第二周期内的第二读写总量以及所述第二应用在所述第二周期内的第四读写总量;其中,所述第一读写操作对应的读写量为第三读写量;
当所述第三读写量、所述第二读写总量与所述第四读写总量之和大于或等于所述管控阈值,在所述第二周期时间内将所述第一应用的第一读写操作对应的数据写入缓存中,以及,在所述第二周期内将所述第二应用的读写操作对应的数据写入所述缓存中;
当所述第三读写量、所述第二读写总量与所述第四读写总量之和大于或等于所述管控阈值,将所述第一读写操作对应的数据输入至缓存中,并通过所述缓存将数据写入存储中,以及,在所述第二周期内将所述第二应用的读写操作对应的数据输入至缓存中,并通过所述缓存将数据写入存储中。
18.根据权利要求12至17任一项所述的设备,其特征在于,当所述计算机程序被所述一个或多个处理器执行时,使得所述电子设备执行以下步骤:
按照设定的触发条件,更新所述管控阈值。
19.根据权利要求12所述的设备,其特征在于,在所述电子设备上的后台运行第一应用的过程中,所述电子设备还运行第三应用,当所述计算机程序被所述一个或多个处理器执行时,使得所述电子设备执行以下步骤:
获取所述第三应用在所述第一周期内的第五读写总量,所述第五读写总量小于所述第一读写总量;
基于所述第五读写总量,判定所述第三应用不满足所述管控条件,确定不需要对所述第三应用在所述第二周期内的读写操作进行所述管控。
20.根据权利要求12所述的设备,其特征在于,当所述计算机程序被所述一个或多个处理器执行时,使得所述电子设备执行以下步骤:
获取所述第一应用在所述第一周期内的多次读写操作中每次读写操作对应的读写量;
获取每次读写操作对应的读写量之和,所述读写量之和为所述第一读写总量。
21.根据权利要求20所述的设备,其特征在于,当所述计算机程序被所述一个或多个处理器执行时,使得所述电子设备执行以下步骤:
在所述第一应用在所述第一周期内进行第一次读写操作时,设置第一输入输出IO时间戳;
在所述第一应用进行第M次读写操作时,检测所述第M次读写操作对应的时刻与所述IO时间戳之间的相对时长是否大于或等于所述第一周期的周期时长;其中,M为大于1的整数;
当所述相对时长大于或等于所述第一周期的周期时长,获取所述第一应用在所述第一周期内的第一读写总量,所述第一读写总量为M次读写操作对应的读写量之和。
22.根据权利要求12所述的设备,其特征在于,当所述计算机程序被所述一个或多个处理器执行时,使得所述电子设备在满足下述条件中的至少一个,获取所述第一应用在第一周期内的第一读写总量:
所述第一电子设备为非息屏状态;
所述第一电子设备在前台运行一个或多个应用;
所述第一电子设备中运行的各应用的读写总量大于第一阈值;
所述一个或多个应用的读写总量大于第二阈值。
23.一种芯片,其特征在于,包括一个或多个接口电路和一个或多个处理器;所述接口电路用于从电子设备的存储器接收信号,并向所述处理器发送所述信号,所述信号包括存储器中存储的计算机指令;当所述处理器执行所述计算机指令时,使得所述电子设备执行权利要求1至11任一项所述的管控方法。
24.一种计算机可读存储介质,包括计算机程序,其特征在于,当所述计算机程序在电子设备上运行时,使得所述电子设备执行如权利要求1-11中任意一项所述的应用的管控方法。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011194269.XA CN114449094B (zh) | 2020-10-30 | 2020-10-30 | 管控方法及电子设备、芯片、存储介质 |
PCT/CN2021/123455 WO2022089206A1 (zh) | 2020-10-30 | 2021-10-13 | 管控方法及电子设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011194269.XA CN114449094B (zh) | 2020-10-30 | 2020-10-30 | 管控方法及电子设备、芯片、存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN114449094A true CN114449094A (zh) | 2022-05-06 |
CN114449094B CN114449094B (zh) | 2023-04-11 |
Family
ID=81357836
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202011194269.XA Active CN114449094B (zh) | 2020-10-30 | 2020-10-30 | 管控方法及电子设备、芯片、存储介质 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN114449094B (zh) |
WO (1) | WO2022089206A1 (zh) |
Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106406763A (zh) * | 2016-09-21 | 2017-02-15 | 郑州云海信息技术有限公司 | 一种后台拷贝方法及装置 |
US20170083447A1 (en) * | 2015-09-22 | 2017-03-23 | EMC IP Holding Company LLC | Method and apparatus for data storage system |
CN107832189A (zh) * | 2017-10-31 | 2018-03-23 | 维沃移动通信有限公司 | 一种i/o系统的监控方法及移动终端 |
US20180293191A1 (en) * | 2015-12-18 | 2018-10-11 | Huawei Technologies Co., Ltd. | Non-volatile storage device and method for accessing non-volatile storage device |
CN108763107A (zh) * | 2018-06-04 | 2018-11-06 | 平安科技(深圳)有限公司 | 后台写盘流控方法、装置、电子设备及存储介质 |
CN108762665A (zh) * | 2018-04-08 | 2018-11-06 | 中兴通讯股份有限公司 | 一种控制存储设备读写的方法及装置 |
CN109144811A (zh) * | 2018-06-29 | 2019-01-04 | 维沃移动通信有限公司 | 一种应用监控方法、装置和移动终端 |
US20190221273A1 (en) * | 2017-04-04 | 2019-07-18 | Sandisk Technologies Llc | Data rewrite during refresh window |
CN110069333A (zh) * | 2019-04-29 | 2019-07-30 | 努比亚技术有限公司 | 应用的后台管控方法、移动终端及计算机可读存储介质 |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106256116B (zh) * | 2015-04-14 | 2019-08-13 | 华为技术有限公司 | 一种控制应用程序的方法及终端 |
CN107423127B (zh) * | 2017-07-31 | 2020-05-12 | Oppo广东移动通信有限公司 | 应用程序的管控方法、装置、存储介质及电子设备 |
CN109388947B (zh) * | 2018-10-30 | 2023-06-20 | 浙江解纷链数字科技有限公司 | 一种后台管理方法、设备及计算机可读存储介质 |
CN109753348A (zh) * | 2018-11-21 | 2019-05-14 | 惠州Tcl移动通信有限公司 | 后台应用程序的管控方法和终端 |
-
2020
- 2020-10-30 CN CN202011194269.XA patent/CN114449094B/zh active Active
-
2021
- 2021-10-13 WO PCT/CN2021/123455 patent/WO2022089206A1/zh active Application Filing
Patent Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20170083447A1 (en) * | 2015-09-22 | 2017-03-23 | EMC IP Holding Company LLC | Method and apparatus for data storage system |
US20180293191A1 (en) * | 2015-12-18 | 2018-10-11 | Huawei Technologies Co., Ltd. | Non-volatile storage device and method for accessing non-volatile storage device |
CN106406763A (zh) * | 2016-09-21 | 2017-02-15 | 郑州云海信息技术有限公司 | 一种后台拷贝方法及装置 |
US20190221273A1 (en) * | 2017-04-04 | 2019-07-18 | Sandisk Technologies Llc | Data rewrite during refresh window |
CN107832189A (zh) * | 2017-10-31 | 2018-03-23 | 维沃移动通信有限公司 | 一种i/o系统的监控方法及移动终端 |
CN108762665A (zh) * | 2018-04-08 | 2018-11-06 | 中兴通讯股份有限公司 | 一种控制存储设备读写的方法及装置 |
CN108763107A (zh) * | 2018-06-04 | 2018-11-06 | 平安科技(深圳)有限公司 | 后台写盘流控方法、装置、电子设备及存储介质 |
CN109144811A (zh) * | 2018-06-29 | 2019-01-04 | 维沃移动通信有限公司 | 一种应用监控方法、装置和移动终端 |
CN110069333A (zh) * | 2019-04-29 | 2019-07-30 | 努比亚技术有限公司 | 应用的后台管控方法、移动终端及计算机可读存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN114449094B (zh) | 2023-04-11 |
WO2022089206A1 (zh) | 2022-05-05 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN112130742B (zh) | 一种移动终端的全屏显示方法及设备 | |
CN109584879B (zh) | 一种语音控制方法及电子设备 | |
WO2021213164A1 (zh) | 应用界面交互方法、电子设备和计算机可读存储介质 | |
CN114443277A (zh) | 内存管理方法、装置、电子设备以及计算机可读存储介质 | |
CN114397981A (zh) | 一种应用显示方法及电子设备 | |
CN111913750B (zh) | 一种应用程序管理方法、装置及设备 | |
CN113704205B (zh) | 日志存储的方法、芯片、电子设备和可读存储介质 | |
CN114556294A (zh) | 一种主题切换方法以及主题切换装置 | |
CN114363462B (zh) | 一种界面显示方法、电子设备及计算机可读介质 | |
CN114461588B (zh) | 调节预读窗口的方法及电子设备 | |
WO2021238370A1 (zh) | 显示控制方法、电子设备和计算机可读存储介质 | |
CN112947947A (zh) | 安装包的下载方法、分发方法、终端设备、服务器及系统 | |
WO2022078105A1 (zh) | 内存管理方法、电子设备以及计算机可读存储介质 | |
CN114730288A (zh) | 一种内存的管理方法及电子设备 | |
CN113688019B (zh) | 响应时长检测方法及装置 | |
CN113641271A (zh) | 应用窗口的管理方法、终端设备及计算机可读存储介质 | |
CN113934519B (zh) | 应用的调度方法及电子设备 | |
CN111249728B (zh) | 一种图像处理方法、装置及存储介质 | |
CN113542574A (zh) | 变焦下的拍摄预览方法、终端、存储介质及电子设备 | |
CN113438366A (zh) | 信息通知的交互方法、电子设备和存储介质 | |
CN112835610A (zh) | 一种构建应用程序资源包的方法、构建装置及终端设备 | |
CN111752648A (zh) | 一种系统语言的切换方法及相关装置 | |
CN113407300B (zh) | 应用误杀评估方法及相关设备 | |
CN114449094B (zh) | 管控方法及电子设备、芯片、存储介质 | |
CN114489469A (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 |