CN109343961B - 内存信息的处理方法、装置、存储介质及终端 - Google Patents

内存信息的处理方法、装置、存储介质及终端 Download PDF

Info

Publication number
CN109343961B
CN109343961B CN201811190841.8A CN201811190841A CN109343961B CN 109343961 B CN109343961 B CN 109343961B CN 201811190841 A CN201811190841 A CN 201811190841A CN 109343961 B CN109343961 B CN 109343961B
Authority
CN
China
Prior art keywords
caller
memory information
memory
calling
time
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201811190841.8A
Other languages
English (en)
Other versions
CN109343961A (zh
Inventor
林进全
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
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 CN201811190841.8A priority Critical patent/CN109343961B/zh
Publication of CN109343961A publication Critical patent/CN109343961A/zh
Application granted granted Critical
Publication of CN109343961B publication Critical patent/CN109343961B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

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/5011Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals
    • G06F9/5016Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals the resource being the memory
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/48Program initiating; Program switching, e.g. by interrupt
    • G06F9/4806Task transfer initiation or dispatching
    • G06F9/4843Task transfer initiation or dispatching by program, e.g. task dispatcher, supervisor, operating system
    • G06F9/4881Scheduling strategies for dispatcher, e.g. round robin, multi-level priority queues
    • 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
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2209/00Indexing scheme relating to G06F9/00
    • G06F2209/48Indexing scheme relating to G06F9/48
    • G06F2209/484Precedence

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Telephone Function (AREA)

Abstract

本申请实施例公开了一种内存信息的处理方法、装置、存储介质及终端,该方法包括:首先接收内存调用者发出的内存信息获取请求;然后,如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔;最后,如果所述调用间隔小于预设间隔,则向所述调用者反馈前一次发送的内存信息,可避免同一应用短时间内多次访问内存信息导致处理器繁忙卡顿,提高资源利用率。

Description

内存信息的处理方法、装置、存储介质及终端
技术领域
本申请实施例涉及移动终端技术领域,尤其涉及内存信息的处理方法、装置、存储介质及终端。
背景技术
随着移动终端的不断发展,终端运算能够不断增强,终端可安装的第三方应用的数量也不断增加。应用的进程在运行过程中会出现获取内存信息的需求,处理器会相应该需求,通过查询内存数据相应该需求。但是如果出现第三方应用恶意的频繁的进行内存数据访问请求,则会占用处理器资源,导致系统卡顿,资源利用率低。
发明内容
本申请实施例的目的是提供一种内存信息的处理方法、装置、存储介质及终端,可以提高终端的资源利用率。
第一方面,本申请实施例提供了一种内存信息的处理方法,包括:
接收内存调用者发出的内存信息获取请求;
如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔;
如果所述调用间隔小于预设间隔,则向所述调用者反馈前一次发送的内存信息。
第二方面,本申请实施例提供了一种内存信息的处理装置,包括:
接收模块,用于接收内存调用者发出的内存信息获取请求;
获取模块,用于如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔;
反馈模块,用于如果所述获取模块获取的所述调用间隔小于预设间隔,则向所述调用者反馈前一次发送的内存信息。
第三方面,本申请实施例提供了一种计算机可读存储介质,其上存储有计算机程序,该程序被处理器执行时实现如第一方面所示的内存信息的处理方法。
第四方面,本申请实施例提供了一种终端,包括存储器,处理器及存储在存储器上并可在处理器运行的计算机程序,所述处理器执行所述计算机程序时实现如第一方面所示的内存信息的处理方法。
本申请实施例中提供的内存信息的处理方案,首先接收内存调用者发出的内存信息获取请求;然后,如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔;最后,如果所述调用间隔小于预设间隔,则向所述调用者反馈前一次发送的内存信息,可避免同一应用短时间内多次访问内存信息导致处理器繁忙卡顿,提高资源利用率。
附图说明
图1为本申请实施例提供的一种内存信息的处理方法的流程示意图。
图2为本申请实施例提供的另一种内存信息的处理方法的流程示意图。
图3为本申请实施例提供的另一种内存信息的处理方法的流程示意图。
图4为本申请实施例提供的另一种内存信息的处理方法的流程示意图。
图5为本申请实施例提供的另一种内存信息的处理方法的流程示意图。
图6为本申请实施例提供的另一种内存信息的处理方法的流程示意图。
图7为本申请实施例提供的一种内存信息的处理装置的结构示意图。
图8为本申请实施例提供的一种移动终端的结构示意图。
具体实施方式
下面结合附图并通过具体实施方式来进一步说明本申请的技术方案。可以理解的是,此处所描述的具体实施例仅仅用于解释本申请,而非对本申请的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与本申请相关的部分而非全部结构。
在更加详细地讨论示例性实施例之前应当提到的是,一些示例性实施例被描述成作为流程图描绘的处理或方法。虽然流程图将各步骤描述成顺序的处理,但是其中的许多步骤可以被并行地、并发地或者同时实施。此外,各步骤的顺序可以被重新安排。当其操作完成时处理可以被终止,但是还可以具有未包括在附图中的附加步骤。处理可以对应于方法、函数、规程、子例程、子程序等等。
随着移动终端的不断发展,终端运算能够不断增强,终端可安装的第三方应用的数量也不断增加。应用的进程在运行过程中会出现获取内存信息的需求,处理器会相应该需求,通过查询内存数据相应该需求。但是如果出现第三方应用恶意的频繁的通过内存状态接口进行内存数据访问,会占用处理器(CPU)资源,导致系统卡顿,资源利用率低。
在Android原生的代码实现中,提供了给应用获取内存信息的方法,通过该方法,系统会进行对当前内存的查询,然后将获取的内存信息反馈给应用。但是当出现恶意访问时,按照目前的Android原生的代码实现方式,将会消耗大量的CPU资源,当频繁调用时,会导致系统出现卡顿情况。
本申请实施例提供了一种内存信息的处理方法,终端能够对进行内存信息访问的应用进行记录,通过判断应用的访问频率进行相应处理,对于访问频率较高的应用,直接将上次反馈的内存信息作为本次反馈信息,进而无需处理器处理本次的内存访问请求,降低处理器负载,提高系统资源利用率。具体方案如下所示:
图1为本申请实施例提供的内存信息的处理方法的流程示意图,该方法用于终端内存信息访问的情况,该方法可以由移动终端来执行,该移动终端可以为智能手机、平板电脑、可穿戴设备、笔记本电脑、个人电脑等,该方法具体包括如下步骤:
步骤110、接收内存调用者发出的内存信息获取请求。
调用者为应用对应的一个进程或多个进程中的任意一个进程。调用者可以在进行内存清理之前发出内存信息获取请求,根据获取到的内存信息对自身对应的内存空间中的数据进行处理。
步骤120、如果调用者为非首次调用,则获取本次调用与调用者前一次调用的时间隔。
首次调用可以为终端本次开机之后的首次调用。调用者每次进行调用后,系统对调用行为进行记录,包括记录调用者、调用时间以及获取的内存信息。当重新启动终端时,可以重置记录。
如果本次为非首次,则根据记录可以获取调用者前一次的调用时间。根据前一次的调用时间和当前系统时间确定时间隔。
可选的,如果当前处理器负载大于预设负载阈值,则判断调用者是否为首次调用。如果调用者为非首次调用,则获取本次调用与调用者前一次调用的时间隔。如果当前处理器负载小于预设负载阈值,则读取内存信息。将内存信息保存到调用者对应进程的内存空间。
负载阈值可以为CPU10%-20%占用率。如果当前处理器大于预设负载阈值,则需要为处理器分流,适度的为处理器过滤非必要处理请求,例如频繁出现的内存信息获取请求。
步骤130、如果调用间隔小于预设间隔,则向调用者反馈前一次发送的内存信息。
预设间隔可以为秒级也可以为分钟级。读取前一次记录的内存内信息,将该内存信息直接反馈给调用者,此时无需处理器进行内存读取操作。
本申请实施例提供的内存信息的处理方法,首先接收内存调用者发出的内存信息获取请求。然后,如果调用者为非首次调用,则获取本次调用与调用者前一次调用的时间隔。最后,如果调用间隔小于预设间隔,则向调用者反馈前一次发送的内存信息,相对于目前缺少内存频繁访问机制,导致处理器被占用,资源利用率低,本申请实施例可以在调用间隔小于预设间隔时,向调用者反馈前一次发送的内存信息,进而避免处理器进行内存信息的读取操作,降低处理器负载,提高资源利用率。
图2为本申请实施例提供的一种内存信息的处理方法的流程示意图,作为对上述实施例的进一步说明,包括:
步骤210、接收内存调用者发出的内存信息获取请求。
步骤220、判断调用者是否为首次调用。
如果为非首次,则执行步骤240。如果为首次,则执行步骤260。
步骤230、如果调用者为非首次调用,则获取本次调用与调用者前一次调用的时间隔。
步骤240、判断调用间隔是否小于预设间隔。
如果小于,执行步骤250。否则执行步骤260。
步骤250、如果调用间隔小于预设间隔,则向调用者反馈前一次发送的内存信息。
步骤260、如果调用者为首次调用,或者时间隔大于预设间隔,则读取内存信息。
如果调用者为首次调用或者时间隔大于预设间隔,则说明调用者的访问频率是正常的。此时处理器读取内存信息。内存信息包括下述信息中的至少一个或多个:实际使用的物理内存(Proportional Set Size,PSS)、交换出去的物理内存、共享内存有效部分、私有内存有效部分、共享内存使用过的数据、私有内存使用过的数据、共享内存清理的数据以及私有内存清理的数据等。
步骤270、将内存信息保存到调用者对应进程的内存空间。
内存空间中为每个进程分配了对应的内存空间,处理器在获取到内存信息后将内存信息写入到调用者对应进程的内存空间。
本申请实施例提供的内存信息的处理方法能够在调用者为首次调用,或者时间隔大于预设间隔,则读取内存信息,为进程提供内存信息的读取服务。
图3为本申请实施例提供的一种内存信息的处理方法的流程示意图,作为对上述实施例的进一步说明,包括:
步骤310、接收内存调用者发出的内存信息获取请求。
步骤320、判断调用者是否为首次调用。
如果为非首次,则执行步骤340。如果为首次,则执行步骤360。
步骤330、如果调用者为非首次调用,则获取本次调用与调用者前一次调用的时间隔。
步骤340、判断调用间隔是否小于预设间隔。
如果小于,执行步骤350。否则执行步骤360。
步骤350、如果调用间隔小于预设间隔,则向调用者反馈前一次发
送的内存信息。
步骤360、如果调用者为首次调用,或者时间隔大于预设间隔,则使用安卓调试类中的预设函数获取目标内存信息。
可选的,安卓调试类中的预设函数可以选择android_os_Debug中对getDirtyPagesPid函数对内存接口进行监控,记录需要反馈的内存信息。
步骤370、读取目标内存信息。
步骤380、将内存信息保存到调用者对应进程的内存空间。
本申请实施例提供的内存信息的处理方法能够在上述实施例的基础上,通过安卓调试类中的预设函数能够准确滑块的获取目标内存信息,提高内存信息读取效率。本申请实施例通过增加对获取系统内存接口的监控,减少处理器被调用次数,避免出现系统卡顿现象,提高资源利用率。
图4为本申请实施例提供的一种内存信息的处理方法的流程示意图,作为对上述实施例的进一步说明,包括:
步骤410、根据内存信息获取请求获取调用者的第一进程标识和被查询的第二进程标识。
内存信息获取请求包括被查询的第二进程,获取第二进程标识以及发起内存信息获取请求的第一进程标识。
步骤420、判断第一进程标识和第二进程标识是否相同。
相同执行步骤430。不同执行步骤460。
步骤430、如果第一进程标识和第二进程标识相同,则接收内存调用者发出的内存信息获取请求。
如果第一进程标识与第二进程标识相同,则说明调用者在查询自身的内存信息,而非其他进程的内存,这种请求是合法的,进而接收内存调用者发出的内存信息获取请求。
步骤440、如果调用者为非首次调用,则获取本次调用与调用者前一次调用的时间隔。
步骤450、如果调用间隔小于预设间隔,则向调用者反馈前一次发送的内存信息。
步骤460、屏蔽调用者发送的内存信息获取请求。
如果第一进程标识与第二进程标识不相同,则说明调用者在查询其他进程的内存信息,这种请求是不合法的,进而屏蔽内存调用者发出的内存信息获取请求。
本申请实施例提供的内存信息的处理方法能够核对调用者的第一进程与被查询的第二进程是否一致,进而判定调用者的合法性,提高系统安全。
图5为本申请实施例提供的一种内存信息的处理方法的流程示意图,作为对上述实施例的进一步说明,包括:
步骤510、根据内存信息获取请求获取调用者的第一进程标识和被查询的第二进程标识。
步骤520、判断第一进程标识和第二进程标识是否相同。
相同执行步骤530。不同执行步骤570。
步骤530、如果第一进程标识和第二进程标识相同,则接收内存调用者发出的内存信息获取请求。
步骤540、如果调用者为非首次调用,则根据第一进程标识获取调用者的第一包名。
第一包名用于标识第一进程对应的应用名称,如果应用通过多个进程进行执行,而多个进程间需要进行内存信息的交互,此时可以将第一包名对隶属于同一个应用的多个进程视为一个请求单位。
步骤550、如果第一包名为非首次调用,则获取本次调用与调用者前一次调用的时间隔。
步骤560、如果调用间隔小于预设间隔,则向调用者反馈前一次发送的内存信息。
步骤570、屏蔽调用者发送的内存信息获取请求。
本申请实施例提供的内存信息的处理方法,能够基于包名反馈调用者应用,实现应用内启动的多个进程之间能够实现内存共享,提高应用执行效率。
图6为本申请实施例提供的一种内存信息的处理方法的流程示意图,作为对上述实施例的进一步说明,包括:
步骤610、接收内存调用者发出的内存信息获取请求。
步骤620、根据调用者类型确定时间隔。
调用者类型可以根据进程自身优先级或者进程对应的应用的优先级进行确定。优先级越高的进程其对应的时间隔越短。可选的,优先级较高的调用者其时间隔可以为3分钟,优先级较低的调用者其时间隔为5分钟。
步骤630、如果调用者为非首次调用,则获取本次调用与调用者前一次调用的时间隔。
步骤640、如果调用间隔小于预设间隔,则向调用者反馈前一次发送的内存信息。
本申请实施例提供的内存信息的处理方法,能够根据调用者类型确定其对应的时间隔,使得优先级较高的调用者的时间隔小于优先级较低的调用者的时间隔,进而更加灵活的对调用者的内存访问请求进行处理。
图7为本申请实施例提供的一种内存信息的处理装置的结构示意图。如图7所示,该装置包括:接收模块710、获取模块720和反馈模块730。
接收模块710,用于接收内存调用者发出的内存信息获取请求;
获取模块720,用于如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔;
反馈模块730,用于如果所述获取模块720获取的所述调用间隔小于预设间隔,则向所述调用者反馈前一次发送的内存信息。
进一步的,获取模块720用于在接收内存调用者发出的内存信息获取请求之后,如果所述调用者为首次调用,或者所述时间隔大于所述预设间隔,则读取内存信息;
将所述内存信息保存到所述调用者对应进程的内存空间。
进一步的,获取模块720用于读取内存信息,包括:
使用安卓调试类中的预设函数获取目标内存信息;
读取所述目标内存信息;
相应的,所述将所述内存信息保存到所述调用者对应进程的内存空间,包括:
将所述内存信息保存到所述调用者对应进程的内存空间。
进一步的,接收模块710用于,根据内存信息获取请求获取调用者的第一进程标识和被查询的第二进程标识;
如果所述第一进程标识和所述第二进程标识相同,则接收内存调用者发出的内存信息获取请求。
进一步的,获取模块720用于,如果所述调用者为非首次调用,则根据第一进程标识获取调用者的第一包名;
如果所述第一包名为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔。
进一步的,获取模块720用于,
根据所述调用者类型确定时间隔;
如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔。
进一步的,获取模块720用于,如果当前处理器负载大于预设负载阈值,则判断所述调用者是否为首次调用;
如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔。
本申请实施例提供的内存信息的处理装置,首先接收模块710接收内存调用者发出的内存信息获取请求;然后,获取模块720用于如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔;最后,反馈模块730用于如果所述调用间隔小于预设间隔,则向所述调用者反馈前一次发送的内存信息,相对于目前缺少内存频繁访问机制,导致处理器被占用,资源利用率低,本申请实施例可以在调用间隔小于预设间隔时,向调用者反馈前一次发送的内存信息,进而避免处理器进行内存信息的读取操作,降低处理器负载,提高资源利用率。
上述装置可执行本申请前述所有实施例所提供的方法,具备执行上述方法相应的功能模块和有益效果。未在本实施例中详尽描述的技术细节,可参见本申请前述所有实施例所提供的方法。
图8是本申请实施例提供的一种终端设备的结构示意图。如图8所示,该终端可以包括:壳体(图中未示出)、存储器801、中央处理器(Central Processing Unit,CPU)802(又称处理器,以下简称CPU)、存储在存储器801上并可在处理器802上运行的计算机程序、电路板(图中未示出)和电源电路(图中未示出)。所述电路板安置在所述壳体围成的空间内部;所述CPU802和所述存储器801设置在所述电路板上;所述电源电路,用于为所述终端的各个电路或器件供电;所述存储器801,用于存储可执行程序代码;所述CPU802通过读取所述存储器801中存储的可执行程序代码来运行与所述可执行程序代码对应的程序。
所述终端还包括:外设接口803、RF(Radio Frequency,射频)电路805、音频电路806、扬声器811、电源管理芯片808、输入/输出(I/O)子系统809、触摸屏812、其他输入/控制设备810以及外部端口804,这些部件通过一个或多个通信总线或信号线807来通信。
应该理解的是,图示终端设备800仅仅是终端的一个范例,并且终端设备800可以具有比图中所示出的更多的或者更少的部件,可以组合两个或更多的部件,或者可以具有不同的部件配置。图中所示出的各种部件可以在包括一个或多个信号处理和/或专用集成电路在内的硬件、软件、或硬件和软件的组合中实现。
下面就本实施例提供的用于一种终端设备进行详细的描述,该终端设备以智能手机为例。
存储器801,所述存储器801可以被CPU802、外设接口803等访问,所述存储器801可以包括高速随机存取存储器,还可以包括非易失性存储器,例如一个或多个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
外设接口803,所述外设接口803可以将设备的输入和输出外设连接到CPU802和存储器801。
I/O子系统809,所述I/O子系统809可以将设备上的输入输出外设,例如触摸屏812和其他输入/控制设备810,连接到外设接口803。I/O子系统809可以包括显示控制器8091和用于控制其他输入/控制设备810的一个或多个输入控制器8092。其中,一个或多个输入控制器8092从其他输入/控制设备810接收电信号或者向其他输入/控制设备810发送电信号,其他输入/控制设备810可以包括物理按钮(按压按钮、摇臂按钮等)、拨号盘、滑动开关、操纵杆、点击滚轮。值得说明的是,输入控制器8092可以与以下任一个连接:键盘、红外端口、USB接口以及诸如鼠标的指示设备。
其中,按照触摸屏的工作原理和传输信息的介质分类,触摸屏812可以为电阻式、电容感应式、红外线式或表面声波式。按照安装方式分类,触摸屏812可以为:外挂式、内置式或整体式。按照技术原理分类,触摸屏812可以为:矢量压力传感技术触摸屏、电阻技术触摸屏、电容技术触摸屏、红外线技术触摸屏或表面声波技术触摸屏。
触摸屏812,所述触摸屏812是用户终端与用户之间的输入接口和输出接口,将可视输出显示给用户,可视输出可以包括图形、文本、图标、视频等。可选的,触摸屏812将用户在触屏幕上触发的电信号(如接触面的电信号),发送给处理器802。
I/O子系统809中的显示控制器8091从触摸屏812接收电信号或者向触摸屏812发送电信号。触摸屏812检测触摸屏上的接触,显示控制器8091将检测到的接触转换为与显示在触摸屏812上的用户界面对象的交互,即实现人机交互,显示在触摸屏812上的用户界面对象可以是运行游戏的图标、联网到相应网络的图标等。值得说明的是,设备还可以包括光鼠,光鼠是不显示可视输出的触摸敏感表面,或者是由触摸屏形成的触摸敏感表面的延伸。
RF电路805,主要用于建立智能音箱与无线网络(即网络侧)的通信,实现智能音箱与无线网络的数据接收和发送。例如收发短信息、电子邮件等。
音频电路806,主要用于从外设接口803接收音频数据,将该音频数据转换为电信号,并且将该电信号发送给扬声器811。
扬声器811,用于将智能音箱通过RF电路805从无线网络接收的语音信号,还原为声音并向用户播放该声音。
电源管理芯片808,用于为CPU802、I/O子系统及外设接口所连接的硬件进行供电及电源管理。
在本实施例中,中央处理器802用于:
接收内存调用者发出的内存信息获取请求;
如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔;
如果所述调用间隔小于预设间隔,则向所述调用者反馈前一次发送的内存信息。
进一步的,在接收内存调用者发出的内存信息获取请求之后,包括:
如果所述调用者为首次调用,或者所述时间隔大于所述预设间隔,则读取内存信息;
将所述内存信息保存到所述调用者对应进程的内存空间。
进一步的,所述读取内存信息,包括:
使用安卓调试类中的预设函数获取目标内存信息;
读取所述目标内存信息;
相应的,所述将所述内存信息保存到所述调用者对应进程的内存空间,包括:
将所述内存信息保存到所述调用者对应进程的内存空间。
进一步的,所述接收内存调用者发出的内存信息获取请求,包括:
根据内存信息获取请求获取调用者的第一进程标识和被查询的第二进程标识;
如果所述第一进程标识和所述第二进程标识相同,则接收内存调用者发出的内存信息获取请求。
进一步的,所述如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔,包括:
如果所述调用者为非首次调用,则根据第一进程标识获取调用者的第一包名;
如果所述第一包名为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔。
进一步的,所述如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔,包括:
根据所述调用者类型确定时间隔;
如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔。
进一步的,所述如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔,包括:
如果当前处理器负载大于预设负载阈值,则判断所述调用者是否为首次调用;
如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔。
本申请实施例还提供一种包含终端设备可执行指令的存储介质,所述终端设备可执行指令在由终端设备处理器执行时用于执行一种内存信息的处理方法,该方法包括:
接收内存调用者发出的内存信息获取请求;
如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔;
如果所述调用间隔小于预设间隔,则向所述调用者反馈前一次发送的内存信息。
进一步的,在接收内存调用者发出的内存信息获取请求之后,包括:
如果所述调用者为首次调用,或者所述时间隔大于所述预设间隔,则读取内存信息;
将所述内存信息保存到所述调用者对应进程的内存空间。
进一步的,所述读取内存信息,包括:
使用安卓调试类中的预设函数获取目标内存信息;
读取所述目标内存信息;
相应的,所述将所述内存信息保存到所述调用者对应进程的内存空间,包括:
将所述内存信息保存到所述调用者对应进程的内存空间。
进一步的,所述接收内存调用者发出的内存信息获取请求,包括:
根据内存信息获取请求获取调用者的第一进程标识和被查询的第二进程标识;
如果所述第一进程标识和所述第二进程标识相同,则接收内存调用者发出的内存信息获取请求。
进一步的,所述如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔,包括:
如果所述调用者为非首次调用,则根据第一进程标识获取调用者的第一包名;
如果所述第一包名为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔。
进一步的,所述如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔,包括:
根据所述调用者类型确定时间隔;
如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔。
进一步的,所述如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔,包括:
如果当前处理器负载大于预设负载阈值,则判断所述调用者是否为首次调用;
如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔。
本申请实施例的计算机存储介质,可以采用一个或多个计算机可读的介质的任意组合。计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本文件中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。
计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括——但不限于无线、电线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言或其组合来编写用于执行本申请操作的计算机程序代码,程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如”C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
当然,本申请实施例所提供的一种包含计算机可执行指令的存储介质,其计算机可执行指令不限于如上所述的内存信息的处理操作,还可以执行本申请任意实施例所提供的内存信息的处理方法中的相关操作。
注意,上述仅为本申请的较佳实施例及所运用技术原理。本领域技术人员会理解,本申请不限于这里所述的特定实施例,对本领域技术人员来说能够进行各种明显的变化、重新调整和替代而不会脱离本申请的保护范围。因此,虽然通过以上实施例对本申请进行了较为详细的说明,但是本申请不仅仅限于以上实施例,在不脱离本申请构思的情况下,还可以包括更多其他等效实施例,而本申请的范围由所附的权利要求范围决定。

Claims (9)

1.一种内存信息的处理方法,其特征在于,包括:
接收内存调用者发出的内存信息获取请求,所述调用者为应用对应的一个进程或多个进程中的任意一个进程;
如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔;
如果所述调用间隔小于预设间隔,则向所述调用者反馈前一次发送的内存信息;
所述接收内存调用者发出的内存信息获取请求,包括:
根据内存信息获取请求获取调用者的第一进程标识和被查询的第二进程标识;
如果所述第一进程标识和所述第二进程标识相同,则接收内存调用者发出的内存信息获取请求。
2.根据权利要求1所述的内存信息的处理方法,其特征在于,在接收内存调用者发出的内存信息获取请求之后,包括:
如果所述调用者为首次调用,或者所述时间隔大于所述预设间隔,则读取内存信息;
将所述内存信息保存到所述调用者对应进程的内存空间。
3.根据权利要求2所述的内存信息的处理方法,其特征在于,所述读取内存信息,包括:
使用安卓调试类中的预设函数获取目标内存信息;
读取所述目标内存信息;
相应的,所述将所述内存信息保存到所述调用者对应进程的内存空间,包括:
将所述内存信息保存到所述调用者对应进程的内存空间。
4.根据权利要求1所述的内存信息的处理方法,其特征在于,所述如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔,包括:
如果所述调用者为非首次调用,则根据第一进程标识获取调用者的第一包名;
如果所述第一包名为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔。
5.根据权利要求1所述的内存信息的处理方法,其特征在于,所述如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔,包括:
根据所述调用者类型确定时间隔;
如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔。
6.根据权利要求1-5中任一项所述的内存信息的处理方法,其特征在于,所述如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔,包括:
如果当前处理器负载大于预设负载阈值,则判断所述调用者是否为首次调用;
如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔。
7.一种内存信息的处理装置,其特征在于,包括:
接收模块,用于接收内存调用者发出的内存信息获取请求,所述调用者为应用对应的一个进程或多个进程中的任意一个进程;
获取模块,用于如果所述调用者为非首次调用,则获取本次调用与所述调用者前一次调用的时间隔;
反馈模块,用于如果所述获取模块获取的所述调用间隔小于预设间隔,则向所述调用者反馈前一次发送的内存信息;
所述接收模块,用于根据内存信息获取请求获取调用者的第一进程标识和被查询的第二进程标识;
如果所述第一进程标识和所述第二进程标识相同,则接收内存调用者发出的内存信息获取请求。
8.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1-6中任一所述内存信息的处理方法。
9.一种终端,包括存储器,处理器及存储在存储器上并可在处理器运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1-6任一所述的内存信息的处理方法。
CN201811190841.8A 2018-10-12 2018-10-12 内存信息的处理方法、装置、存储介质及终端 Active CN109343961B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201811190841.8A CN109343961B (zh) 2018-10-12 2018-10-12 内存信息的处理方法、装置、存储介质及终端

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201811190841.8A CN109343961B (zh) 2018-10-12 2018-10-12 内存信息的处理方法、装置、存储介质及终端

Publications (2)

Publication Number Publication Date
CN109343961A CN109343961A (zh) 2019-02-15
CN109343961B true CN109343961B (zh) 2021-07-09

Family

ID=65309477

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201811190841.8A Active CN109343961B (zh) 2018-10-12 2018-10-12 内存信息的处理方法、装置、存储介质及终端

Country Status (1)

Country Link
CN (1) CN109343961B (zh)

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110287007A (zh) * 2019-05-20 2019-09-27 深圳壹账通智能科技有限公司 数据调用响应方法、服务器及计算机可读存储介质

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6003115A (en) * 1997-07-29 1999-12-14 Quarterdeck Corporation Method and apparatus for predictive loading of a cache
CN1242903A (zh) * 1997-10-24 2000-01-26 株式会社东芝 通信终端装置
CN102968507A (zh) * 2012-12-14 2013-03-13 中国银行股份有限公司 基于缓存表的数据查询方法
CN103914337A (zh) * 2014-03-24 2014-07-09 小米科技有限责任公司 服务调用方法、装置及终端
CN103914363A (zh) * 2012-12-31 2014-07-09 华为技术有限公司 一种内存监控方法及相关装置
CN105956111A (zh) * 2016-05-03 2016-09-21 中山市奥创通风设备有限公司 空气净化器的云服务智能控制系统
CN106484531A (zh) * 2016-09-18 2017-03-08 上海顺久电子科技有限公司 内存访问仲裁方法、电路及装置

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101599048B (zh) * 2009-07-01 2012-02-22 福建星网锐捷网络有限公司 一种内存监控的方法和装置
US8639815B2 (en) * 2011-08-31 2014-01-28 International Business Machines Corporation Selecting a primary-secondary host pair for mirroring virtual machines
CN103873590B (zh) * 2014-04-01 2017-04-26 北京奇立软件技术有限公司 一种网页im的接入方法和网页浏览器

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6003115A (en) * 1997-07-29 1999-12-14 Quarterdeck Corporation Method and apparatus for predictive loading of a cache
CN1242903A (zh) * 1997-10-24 2000-01-26 株式会社东芝 通信终端装置
CN102968507A (zh) * 2012-12-14 2013-03-13 中国银行股份有限公司 基于缓存表的数据查询方法
CN103914363A (zh) * 2012-12-31 2014-07-09 华为技术有限公司 一种内存监控方法及相关装置
CN103914337A (zh) * 2014-03-24 2014-07-09 小米科技有限责任公司 服务调用方法、装置及终端
CN105956111A (zh) * 2016-05-03 2016-09-21 中山市奥创通风设备有限公司 空气净化器的云服务智能控制系统
CN106484531A (zh) * 2016-09-18 2017-03-08 上海顺久电子科技有限公司 内存访问仲裁方法、电路及装置

Also Published As

Publication number Publication date
CN109343961A (zh) 2019-02-15

Similar Documents

Publication Publication Date Title
CN108710515B (zh) 应用预加载方法、装置、存储介质及终端
CN109960507B (zh) 编译优化方法、装置、存储介质、智能终端及服务器
CN107734616B (zh) 应用程序关闭方法、装置、存储介质和电子设备
CN107835033B (zh) 天线调谐开关的控制方法、装置、终端设备及存储介质
CN106095284B (zh) 电子设备
CN108681474B (zh) 应用预加载方法、装置、存储介质及终端
CN107748685B (zh) 应用程序启动控制方法、装置、终端设备及存储介质
CN109840418B (zh) 应用程序的跳转控制方法、装置、存储介质及终端
CN107797841B (zh) 窗口控制方法、装置、终端设备及存储介质
CN107402835A (zh) 应用程序的异常处理方法、装置及存储介质和移动终端
CN108038231B (zh) 日志处理方法、装置、终端设备及存储介质
US10534425B2 (en) Processing method and device for saving power, mobile terminal and cloud server
US10474507B2 (en) Terminal application process management method and apparatus
CN109408465B (zh) 文件归属信息记录方法、装置、存储介质及终端
CN109033247B (zh) 一种应用程序的管理方法、装置、存储介质及终端
CN107026933B (zh) 一种多开应用的消息管理方法、装置及智能终端
US11077377B2 (en) Method for game loading and related products
WO2019100869A1 (en) Processing method, device and storage medium for implementing automatic startup
CN107831886B (zh) 关联启动应用的管控方法、装置、存储介质及智能终端
CN106937258B (zh) 一种广播的控制方法、装置及移动终端
CN109495573A (zh) 数据传输方法、装置、存储介质及终端
CN108196664B (zh) 屏幕显示方法、装置、存储介质及终端
CN106502732B (zh) 一种应用程序的关闭方法、装置及智能终端
CN111104180A (zh) 应用程序优化方法、装置、存储介质及电子设备
CN109343961B (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