CN102289410A - 基于mtk平台的内存分配状况监控方法 - Google Patents

基于mtk平台的内存分配状况监控方法 Download PDF

Info

Publication number
CN102289410A
CN102289410A CN201110180904A CN201110180904A CN102289410A CN 102289410 A CN102289410 A CN 102289410A CN 201110180904 A CN201110180904 A CN 201110180904A CN 201110180904 A CN201110180904 A CN 201110180904A CN 102289410 A CN102289410 A CN 102289410A
Authority
CN
China
Prior art keywords
memory
piece
duty
takies
steps
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
Application number
CN201110180904A
Other languages
English (en)
Other versions
CN102289410B (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.)
HANGZHOU SKY-MOBI TECHNOLOGY Co Ltd
Original Assignee
HANGZHOU SKY-MOBI TECHNOLOGY Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by HANGZHOU SKY-MOBI TECHNOLOGY Co Ltd filed Critical HANGZHOU SKY-MOBI TECHNOLOGY Co Ltd
Priority to CN201110180904.3A priority Critical patent/CN102289410B/zh
Publication of CN102289410A publication Critical patent/CN102289410A/zh
Application granted granted Critical
Publication of CN102289410B publication Critical patent/CN102289410B/zh
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Debugging And Monitoring (AREA)

Abstract

本发明涉及一种基于MTK平台的内存分配状况监控方法,包括如下步骤:获取系统整个内存块的起始地址、结束地址、内存总量;获取所有空闲块的起始地址、结束地址;绘制形成一个内存总量占空图,在内存图中,以第一颜色填充内存空闲块,以第二颜色填充内存占用块。在MTK平台的终端开发中,通过图形的方式展现应用内存的分配情况,可以在程序运行的任意时刻通过快捷键呼出调试界面,在调试界面可以清晰的展示当前应用对系统内存总量的占用情况、空闲情况。程序运行中,这种形象直观的实时内存占空情况获取方式,有助于帮助用户在开发过程中及时发现内存越界使用、内存碎片内存泄露等问题,及时对内存进行调试、优化。

Description

基于MTK平台的内存分配状况监控方法
技术领域
本发明涉及一种基于MTK平台的内存分配状况监控方法。
背景技术
在编程时进行内存分配是十分重要的,动态内存可以在程序运行过程中帮助分配所需的内存空间,而不是在进程启动的时间就进行分配,然后,有效地管理动态内存同样也是非常重要的,特别是在嵌入式等资源受限环境的软件开发过程中。
在利用C语言进行嵌入式程序开发过程中,常存在如下几个内存问题:
1、内存越界使用,即使用了不该使用的内存,当内存输入超出了预分配的空间大小,就会覆盖该空间之后的一段存储区域,导致系统异常;
2、内存碎片,以小而不连续方式出现在系统不同位置的所有不可用的空闲内存;
3、内存泄露,以前分配的一片内存不再需要使用或无法访问时,没有被释放掉,导致某一进程的总可用内存减少,应用程序失去了对分配内存的控制;
    开发人员往往需要花费很大的施加和精力调试内存越界导致的死机问题、内存碎片导致的内存不足问题、或是内存泄漏导致的因可用内存数量减少而导致的设备性能降低的问题。
现有技术中,程序开发过程中的内存优化全部依靠打印等方式进行,不仅无法实时的显示当前的系统内存情况、应用内存情况,而且不够形象直观。
发明内容
本发明的目的在于克服现有技术中存在的问题,提出一种通过图形化的方式显示内存使用情况的基于MTK平台的内存分配状况监控方法。
为达到上述目的,本发明所采用的技术方案是:
一种基于MTK平台的内存分配状况监控方法,包括如下步骤:
(S001)获取系统整个内存块的起始地址、结束地址、内存总量;
(S002)获取所有空闲块的起始地址、结束地址;
(S003)绘制形成一个内存总量占空图,在内存图中,以第一颜色填充内存空闲块,以第二颜色填充内存占用块。
应用上述技术方案,可以直观的了解当前系统内存的使用量、剩余量、碎片分布情况,便于优化程序的内存管理;另外,在程序运行过程中,可以实时监控内存峰值情况,便于优化程序峰值内存;再者,采用实地址模式的程序编写过程中,经常出现内存越界造成的内存管理数据破坏,通过图形化的内存监控方法可以判断导致异常发生的原因及异常情况,例如,已申请内存无故变大、变小,剩余内存块异常变化等;最后,可以检测到内存泄漏的产生,如果剩余内存块在程序运行过程中持续减少,那很可能是程序中发生了内存泄漏。
上述技术方案还可以进一步优化:
作为优选,它还包括如下步骤:
(S004)用户指定一个内存占用块;
(S005)获取指定占用块的起始地址、结束地址、占用量;
(S006)获取指定占用块内的所有空闲块的起始地址、结束地址;
(S007)绘制形成一个第一级指定占用块的占空图。
    作为优选,在指定占用块的占空图中,以第一颜色填充内存空闲块、以第二颜色填充内存占用块。
作为优选,它还包括如下步骤:
(S008)对一个第一级指定占用块的占空图重复执行步骤(S004)~(S007),获取一个第二级指定占用块的占空图;
(S009)对一个第n-1级指定占用块的占空图重复执行步骤(S004)~(S007),获取一个第n级指定占用块的占空图。
    作为优选,它还进一步包括如下步骤:
(S0010)组合内存总量占空图、根据指定生成的一个第一级至第n级指定占用块的占空图,形成内存调试界面并显示。
作为优选,设定优先级最高的当前应用所在的内存占用块为默认的指定占用块。
作为优选,内存调试界面通过设定的快捷键呼出。
作为优选,它还包括如下步骤:
(S011)当运行的应用出现内存管理节点异常时,在内存调试界面显示错误信息。
由于上述技术方案的采用,本发明与现有技术相比,具有以下优点:
在MTK平台的终端开发中,通过图形的方式展现应用内存的分配情况,可以在程序运行的任意时刻通过快捷键呼出调试界面,在调试界面可以清晰的展示当前应用对系统内存总量的占用情况、空闲情况。采用本发明所提供的技术方案还可以根据用户指定获取某一运行应用的详细内存占空情况,进一步的,获取下一级或多级的内存占空情况。程序运行中,这种形象直观的实时内存占空情况获取方式,有助于帮助用户在开发过程中及时发现内存越界使用、内存碎片内存泄露等问题,及时对内存进行调试、优化。
附图说明
图1为本发明的一种内存调试界面的示意图。
具体实施方式
下面结合附图,对本发明的具体实施方式做进一步说明。
一种基于MTK平台的内存分配状况监控方法,包括如下步骤:
(S001)获取系统整个内存块的起始地址、结束地址、内存总量;
(S002)获取所有空闲块的起始地址、结束地址;
(S003)绘制形成一个内存总量占空图,如图1的第一行矩形图所示,在内存图中,以第一颜色填充内存空闲块,以第二颜色填充内存占用块;
步骤(S001)~(S003)形成的一个一定长度、一定高度的矩形条,矩形条的长度与系统内存块的内存总量、地址形成对应关系,并且,基于所有内存空间均已被占用的假设,采用第二颜色填充这个矩形条。对于任一空闲块,利用其起始地址、长度,根据对应关系找到其在内存总量矩形条上对应的位置,用第一颜色填充成内存空闲块。
内存空闲块采用遍历整个内存块的方式获得,自系统整个内存块的起始地址开始遍历整个内存块,当获取一个内存空闲块后,将其标识为当前空闲块,并判断当前空闲块是否为最后一个空闲块,如果不是,则采用第一颜色绘制当前空闲块,空闲块的高度与内存总量矩形条的高度相同;如果是,则显示最终的内存总量的占空图。
基于MTK平台的内存分配状况监控方法,还进一步包括如下步骤:
    (S004)用户指定一个内存占用块,或者根据设定,将优先级最高的当前应用或程序所在的内存占用块为默认的指定占用块;
(S005)获取指定占用块的起始地址、结束地址、占用量;
(S006)获取指定占用块内的所有空闲块的起始地址、结束地址;
(S007)绘制形成一个第一级指定占用块的占空图,如图1的第二行矩形图所示,在这个占空图中,以第一颜色填充内存空闲块、以第二颜色填充内存占用块,并且,指定占用块中的空闲块获取方式、指定占用块的占空图的形成方式与内存总量占空图的形成方式相同;
(S008)对一个第一级指定占用块的占空图重复执行步骤(S004)~(S007),获取一个第二级指定占用块的占空图;
(S009)对一个第n-1级指定占用块的占空图重复执行步骤(S004)~(S007),获取一个第n级指定占用块的占空图,在图1中,给出了基于ModuleA的内存占空情况生成的第一级指定占用块的占空图,以及基于ModuleA的ModuleB部分的内存占空情况生成的第二级指定占用块的占空图;
(S0010)组合内存总量占空图、根据指定生成的一个第一级至第n级指定占用块的占空图,形成内存调试界面并显示,内存调试界面通过设定的快捷键呼出,如图1所示;
(S011)当运行的应用出现内存管理节点异常时,在内存调试界面显示错误信息。
内存调试界面还同时显示内存总量、空闲量,指定内存占用块的起始地址、结束地址、以及当前指定内存占用块中,每个运行程序模块所对应的内存占用块的内存占用量。如果没有指定某个内存占用块,则显示内存总量占空图中,每个运行程序所占用的内存量。
应用本实施例所涉及的内存分配状况监控方法,可以直观的了解当前系统内存的使用量、剩余量、碎片分布情况,便于优化程序的内存管理;另外,在程序运行过程中,可以实时监控内存峰值情况,便于优化程序峰值内存;再者,采用实地址模式的程序编写过程中,经常出现内存越界造成的内存管理数据破坏,通过图形化的内存监控方法可以判断导致异常发生的原因及异常情况,例如,已申请内存无故变大、变小,剩余内存块异常变化等;最后,可以检测到内存泄漏的产生,如果剩余内存块在程序运行过程中持续减少,那很可能是程序中发生了内存泄漏。
应理解,该实施例仅用于说明本发明而不用于限制本发明的范围。此外应理解,在阅读了本发明讲授的内容之后,本领域技术人员可以对本发明作各种改动或修改、等同替换等,这些等价形式同样落于本申请所附权利要求书所限定的范围。

Claims (8)

1.一种基于MTK平台的内存分配状况监控方法,包括如下步骤:
(S001)获取系统整个内存块的起始地址、结束地址、内存总量;
(S002)获取所有空闲块的起始地址、结束地址;
(S003)绘制形成一个内存总量占空图,在所述的内存图中,以第一颜色填充内存空闲块,以第二颜色填充内存占用块。
2.根据权利要求1所述的基于MTK平台的内存分配状况监控方法,其特征在于,它还包括如下步骤:
(S004)用户指定一个内存占用块;
(S005)获取指定占用块的起始地址、结束地址、占用量;
(S006)获取指定占用块内的所有空闲块的起始地址、结束地址;
(S007)绘制形成一个第一级指定占用块的占空图。
3.根据权利要求2所述的基于MTK平台的内存分配状况监控方法,其特征在于,在所述的指定占用块的占空图中,以第一颜色填充内存空闲块、以第二颜色填充内存占用块。
4.根据权利要求2或3所述的基于MTK平台的内存分配状况监控方法,其特征在于,它还包括如下步骤:
(S008)对一个第一级指定占用块的占空图重复执行步骤(S004)~(S007),获取一个第二级指定占用块的占空图;
(S009)对一个第n-1级指定占用块的占空图重复执行步骤(S004)~(S007),获取一个第n级指定占用块的占空图。
5.根据权利要求4所述的基于MTK平台的内存分配状况监控方法,其特征在于,它还进一步包括如下步骤:
(S010)组合所述的内存总量占空图、根据指定生成的一个所述的第一级至第n级指定占用块的占空图,形成内存调试界面并显示。
6.根据权利要求5所述的基于MTK平台的内存分配状况监控方法,其特征在于,设定优先级最高的当前应用所在的内存占用块为默认的指定占用块。
7.根据权利要求6所述的基于MTK平台的内存分配状况监控方法,其特征在于,所述的内存调试界面通过设定的快捷键呼出。
8.根据权利要求5所述的基于MTK平台的内存分配状况监控方法,其特征在于,它还包括如下步骤:
(S011)当运行的应用出现内存管理节点异常时,在所述的内存调试界面显示错误信息。
CN201110180904.3A 2011-06-30 2011-06-30 基于mtk平台的内存分配状况监控方法 Expired - Fee Related CN102289410B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201110180904.3A CN102289410B (zh) 2011-06-30 2011-06-30 基于mtk平台的内存分配状况监控方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201110180904.3A CN102289410B (zh) 2011-06-30 2011-06-30 基于mtk平台的内存分配状况监控方法

Publications (2)

Publication Number Publication Date
CN102289410A true CN102289410A (zh) 2011-12-21
CN102289410B CN102289410B (zh) 2014-03-12

Family

ID=45335852

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201110180904.3A Expired - Fee Related CN102289410B (zh) 2011-06-30 2011-06-30 基于mtk平台的内存分配状况监控方法

Country Status (1)

Country Link
CN (1) CN102289410B (zh)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105426306A (zh) * 2015-11-04 2016-03-23 武汉微创光电股份有限公司 一种系统测试中内存测试的方法
CN106776342A (zh) * 2017-01-03 2017-05-31 百度在线网络技术(北京)有限公司 一种对移动应用的内存对象进行分析的方法和装置
CN109408235A (zh) * 2018-10-19 2019-03-01 珠海金山网络游戏科技有限公司 一种数据处理方法及装置、一种计算设备及存储介质
CN112100022A (zh) * 2020-08-14 2020-12-18 北京航空航天大学 一种安卓系统上监测Java对象内存泄漏时即时记录对象分配点的方法

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1752941A (zh) * 2004-09-20 2006-03-29 华为技术有限公司 一种内存监控的装置及方法
CN101515247A (zh) * 2009-03-30 2009-08-26 福建星网锐捷网络有限公司 一种内存监控的方法和装置

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1752941A (zh) * 2004-09-20 2006-03-29 华为技术有限公司 一种内存监控的装置及方法
CN101515247A (zh) * 2009-03-30 2009-08-26 福建星网锐捷网络有限公司 一种内存监控的方法和装置

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
聂仁良 等: "《中文Windows XP课堂》", 31 October 2004, 清华大学出版社 *

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105426306A (zh) * 2015-11-04 2016-03-23 武汉微创光电股份有限公司 一种系统测试中内存测试的方法
CN106776342A (zh) * 2017-01-03 2017-05-31 百度在线网络技术(北京)有限公司 一种对移动应用的内存对象进行分析的方法和装置
CN109408235A (zh) * 2018-10-19 2019-03-01 珠海金山网络游戏科技有限公司 一种数据处理方法及装置、一种计算设备及存储介质
CN112100022A (zh) * 2020-08-14 2020-12-18 北京航空航天大学 一种安卓系统上监测Java对象内存泄漏时即时记录对象分配点的方法

Also Published As

Publication number Publication date
CN102289410B (zh) 2014-03-12

Similar Documents

Publication Publication Date Title
CN102541657B (zh) 用于对硬件加速器进行运行时功能分配的方法和设备
CN102289410B (zh) 基于mtk平台的内存分配状况监控方法
CN106375115A (zh) 资源分配方法及装置
KR101155202B1 (ko) 멀티 코어 프로세서의 전력 관리 방법, 멀티 코어 프로세서의 전력 관리 방법이 기록된 기록매체 및 이를 실행하는 멀티 코어 프로세서 시스템
DE102006019839A1 (de) Zeitbewusste Systeme
US10331191B2 (en) Program and data annotation for hardware customization and energy optimization
WO2024041052A1 (zh) 带宽划分方法、装置、设备及计算机可读存储介质
CN106020967A (zh) 一种混合式云资源自动扩容方法
CN110930291B (zh) 一种gpu显存管理控制方法及相关装置
CN112328170B (zh) 一种云硬盘的扩容方法、装置、计算机设备和存储介质
US20140100838A1 (en) System, method and apparatus for handling power limit restrictions in flash memory devices
US20170147470A1 (en) Method and system for time-based data generation
CN108965471A (zh) 一种智能电视上浏览器内存改善方法
CN108958891B (zh) 一种虚拟机内存分配方法、装置及终端
CN106385377A (zh) 一种信息处理方法和系统
CN103218219A (zh) 紧凑函数跟踪
CN105094742B (zh) 一种写数据的方法和设备
CN104750546A (zh) 一种调整连接池的方法及系统
CN111176570B (zh) 一种厚置备卷创建方法、装置、设备及介质
CN103457996B (zh) 一种协议一致性测试系统内部数据存储方法及系统
JP2015041330A (ja) Cpuの制御方法、制御プログラム、情報処理装置
CN107957878B (zh) 一种基于存储资源再分配的嵌入式设备软件在线升级方法
CN114880079A (zh) 基于强化学习的Kubernetes集群规模调整方法、系统及设备
CN113672176B (zh) 一种数据读取方法、系统、设备及计算机可读存储介质
CN116088662A (zh) 功耗管理方法、多处理单元系统和功耗管理模组

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant
CF01 Termination of patent right due to non-payment of annual fee
CF01 Termination of patent right due to non-payment of annual fee

Granted publication date: 20140312

Termination date: 20170630