CN110704217A - 一种内存泄露检测方法、终端及计算机可读存储介质 - Google Patents

一种内存泄露检测方法、终端及计算机可读存储介质 Download PDF

Info

Publication number
CN110704217A
CN110704217A CN201910797482.0A CN201910797482A CN110704217A CN 110704217 A CN110704217 A CN 110704217A CN 201910797482 A CN201910797482 A CN 201910797482A CN 110704217 A CN110704217 A CN 110704217A
Authority
CN
China
Prior art keywords
memory
application
information
release
leak detection
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
CN201910797482.0A
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.)
Nubia Technology Co Ltd
Original Assignee
Nubia 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 Nubia Technology Co Ltd filed Critical Nubia Technology Co Ltd
Priority to CN201910797482.0A priority Critical patent/CN110704217A/zh
Publication of CN110704217A publication Critical patent/CN110704217A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/0706Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment
    • G06F11/073Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment in a memory management context, e.g. virtual memory or cache management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/362Software debugging
    • G06F11/366Software debugging using diagnostics

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Quality & Reliability (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Debugging And Monitoring (AREA)

Abstract

本发明公开了一种内存泄露检测方法、终端及计算机可读存储介质,该内存泄露检测方法通过对终端上各应用内存申请和释放进行监控,当应用进行内存申请时,记录应用的内存申请信息,当应用进行内存释放时,记录应用的内存释放信息,进一步地,显示内存申请信息与内存释放信息;解决了现有技术中没有完善的内存泄漏检测方案,导致内存泄漏后很难定位并解决,大大增加了软件开发难度的问题。本发明还公开了一种终端及计算机可读存储介质,通过实施上述方案,实现了应用内存泄漏的快速排查和定位,大大降低了软件开发难度,为开发人员带来诸多便利。

Description

一种内存泄露检测方法、终端及计算机可读存储介质
技术领域
本发明涉及终端安全技术领域,更具体地说,涉及一种内存泄露检测方法、终端及计算机可读存储介质。
背景技术
内存泄露是软件开发过程中的常见问题。内存泄露(Memory Leak),是指在应用程序运行过程中,分配的内存由于某种原因未释放或无法释放,浪费了系统内存,且易导致应用程序运行速度减慢甚至整个系统崩溃等严重后果。其中,内存泄漏缺陷具有隐蔽性、积累性的特征,比其他内存非法访问错误更难检测,目前,还没有完善的内存泄漏检测方案,导致内存泄漏后很难定位并解决,大大增加了软件开发的难度。
发明内容
本发明要解决的技术问题在于现有技术中没有完善的内存泄漏检测方案,导致内存泄漏后很难定位并解决,大大增加了软件开发难度的问题。针对该技术问题,提供一种内存泄露检测方法、终端及计算机可读存储介质。
为解决上述技术问题,本发明提供一种内存泄露检测方法,所述内存泄露检测方法包括:
对终端上各应用内存申请和释放进行监控,当所述应用进行内存申请时,记录所述应用的内存申请信息,当所述应用进行内存释放时,记录所述应用的内存释放信息;
显示所述内存申请信息与内存释放信息。
可选地,所述内存申请信息包括:内存申请大小、内存申请位置以及调用栈信息;
所述内存释放信息包括:内存释放大小、内存释放位置。
可选地,所述显示所述内存申请信息与内存释放信息之前,还包括:
根据所述内存申请信息与内存释放信息统计内存泄露大小;
判断所述内存泄露大小是否超过预设阈值;
若是,显示所述内存申请信息与内存释放信息。
可选地,所述根据所述内存申请信息与内存释放信息统计内存泄露大小,包括:
从所述内存申请信息中确定出内存申请的总大小;
从所述内存释放信息中确定出内存释放的总大小;
根据所述内存申请的总大小与所述内存释放的总大小计算内存泄露大小。
可选地,所述显示所述内存申请信息与内存释放信息之前,还包括:
在所述应用的运行过程中,对所述应用占用的内存大小进行周期性采样得到预设时间段内的采样数据;
根据所述采样数据生成内存占用曲线图;
判断所述内存占用曲线图走势是否为递增走势;
若是,判定当前处于内存泄露,显示所述内存申请信息与内存释放信息。
可选地,所述记录所述应用的内存申请与释放信息之前,还包括:
当所述应用开始运行时,为其分配预设大小的内存,以用于存储内存申请信息和应用进行内存释放时的内存释放信息。
可选地,所述显示所述内存申请信息与内存释放信息,包括:
将所述内存申请信息与内存释放信息写入至日志文件中,并显示所述日志文件。
可选地,所述显示所述日志文件之前,还包括:发出告警通知信息。
进一步地,本发明还提供了一种终端,所述终端包括处理器、存储器及通信总线;
所述通信总线用于实现所述处理器和所述存储器之间的连接通信;
所述处理器用于执行所述存储器中存储的一个或者多个程序,以实现如上述任一项所述的内存泄露检测方法的步骤。
进一步地,本发明还提供了一种计算机可读存储介质,所述计算存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现如上述所述的内存泄露检测方法的步骤。
有益效果
本发明提出的内存泄露检测方法、终端及计算机可读存储介质,该内存泄露检测方法通过对终端上各应用内存申请和释放进行监控,当应用进行内存申请时,记录应用的内存申请信息,当应用进行内存释放时,记录应用的内存释放信息,进一步地,显示内存申请信息与内存释放信息;解决了现有技术中没有完善的内存泄漏检测方案,导致内存泄漏后很难定位并解决,大大增加了软件开发难度的问题。也即在本发明中,对终端上各应用内存申请和释放时的内存申请信息和内存释放信息进行了记录,后续开发人员可以通过查看内存申请信息和内存释放信息,排查和定位应用内存泄漏,避免了内存泄露后难以定位的现象发生,大大降低了软件开发难度,为开发人员带来诸多便利。
附图说明
下面将结合附图及实施例对本发明作进一步说明,附图中:
图1为实现本发明各个实施例一个可选的移动终端的硬件结构示意图;
图2为如图1所示的移动终端的无线通信系统示意图;
图3为本发明第一实施例提供的一种内存泄露检测方法的基本流程示意图;
图4为本发明第一实施例提供的一种显示内存申请信息与内存释放信息之前的基本流程示意图;
图5为本发明第一实施例提供的根据内存申请信息与内存释放信息统计内存泄露大小的基本流程示意图;
图6为本发明第一实施例提供的另一种显示内存申请信息与内存释放信息之前的基本流程示意图;
图7为本发明第一实施例提供的一种根据采样数据生成的内存占用曲线图的示意图;
图8为本发明第二实施例提供的一种具体的内存泄露检测方法的基本流程示意图;
图9为本发明第三实施例提供的终端的结构示意图。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。
终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(Personal Digital Assistant,PDA)、便捷式媒体播放器(Portable Media Player,PMP)、导航装置、可穿戴设备、智能手环、计步器等移动终端,以及诸如数字TV、台式计算机等固定终端。
后续描述中将以移动终端为例进行说明,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。
请参阅图1,其为实现本发明各个实施例的一种移动终端的硬件结构示意图,该移动终端100可以包括:RF(Radio Frequency,射频)单元101、WiFi模块102、音频输出单元103、A/V(音频/视频)输入单元104、传感器105、显示单元106、用户输入单元107、接口单元108、存储器109、处理器110、以及电源111等部件。本领域技术人员可以理解,图1中示出的移动终端结构并不构成对移动终端的限定,移动终端可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
下面结合图1对移动终端的各个部件进行具体的介绍:
射频单元101可用于收发信息或通话过程中,信号的接收和发送,具体的,射频单元101可以将上行信息发送给基站,另外也可以将基站发送的下行信息接收后,发送给移动终端的处理器110处理,基站向射频单元101发送的下行信息可以是根据射频单元101发送的上行信息生成的,也可以是在检测到移动终端的信息更新后主动向射频单元101推送的,例如,在检测到移动终端所处的地理位置发生变化后,基站可以向移动终端的射频单元101发送地理位置变化的消息通知,射频单元101在接收到该消息通知后,可以将该消息通知发送给移动终端的处理器110处理,移动终端的处理器110可以控制该消息通知显示在移动终端的显示面板1061上;通常,射频单元101包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器、双工器等。此外,射频单元101还可以通过无线通信与网络和其他设备通信,具体的可以包括:通过无线通信与网络系统中的服务器通信,例如,移动终端可以通过无线通信从服务器中下载文件资源,比如可以从服务器中下载应用程序,在移动终端将某一应用程序下载完成之后,若服务器中该应用程序对应的文件资源更新,则该服务器可以通过无线通信向移动终端推送资源更新的消息通知,以提醒用户对该应用程序进行更新。上述无线通信可以使用任一通信标准或协议,包括但不限于GSM(Global System ofMobile communication,全球移动通讯系统)、GPRS(General Packet Radio Service,通用分组无线服务)、CDMA2000(Code Division Multiple Access 2000,码分多址2000)、WCDMA(Wideband Code Division Multiple Access,宽带码分多址)、TD-SCDMA(Time Division-Synchronous Code Division Multiple Access,时分同步码分多址)、FDD-LTE(FrequencyDivision Duplexing-Long Term Evolution,频分双工长期演进)和TDD-LTE(TimeDivision Duplexing-Long Term Evolution,分时双工长期演进)等。
WiFi属于短距离无线传输技术,移动终端通过WiFi模块102可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图1示出了WiFi模块102,但是可以理解的是,其并不属于移动终端的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。
音频输出单元103可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将射频单元101或WiFi模块102接收的或者在存储器109中存储的音频数据转换成音频信号并且输出为声音。而且,音频输出单元103还可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出单元103可以包括扬声器、蜂鸣器等等。
A/V输入单元104用于接收音频或视频信号。A/V输入单元104可以包括图形处理器(Graphics Processing Unit,GPU)1041和麦克风1042,图形处理器1041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元106上。经图形处理器1041处理后的图像帧可以存储在存储器109(或其它存储介质)中或者经由射频单元101或WiFi模块102进行发送。麦克风1042可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风1042接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由射频单元101发送到移动通信基站的格式输出。麦克风1042可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。
移动终端100还包括至少一种传感器105,比如光传感器、运动传感器以及其他传感器。具体地,光传感器包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板1061的亮度,接近传感器可在移动终端100移动到耳边时,关闭显示面板1061和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于手机还可配置的指纹传感器、压力传感器、虹膜传感器、分子传感器、陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。
显示单元106用于显示由用户输入的信息或提供给用户的信息。显示单元106可包括显示面板1061,可以采用液晶显示器(Liquid Crystal Display,LCD)、有机发光二极管(Organic Light-Emitting Diode,OLED)等形式来配置显示面板1061。
用户输入单元107可用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入。具体地,用户输入单元107可包括触控面板1071以及其他输入设备1072。触控面板1071,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板1071上或在触控面板1071附近的操作),并根据预先设定的程式驱动相应的连接装置。触控面板1071可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器110,并能接收处理器110发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板1071。除了触控面板1071,用户输入单元107还可以包括其他输入设备1072。具体地,其他输入设备1072可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种,具体此处不做限定。
进一步地,触控面板1071可覆盖显示面板1061,当触控面板1071检测到在其上或附近的触摸操作后,传送给处理器110以确定触摸事件的类型,随后处理器110根据触摸事件的类型在显示面板1061上提供相应的视觉输出。虽然在图1中,触控面板1071与显示面板1061是作为两个独立的部件来实现移动终端的输入和输出功能,但是在某些实施例中,可以将触控面板1071与显示面板1061集成而实现移动终端的输入和输出功能,具体此处不做限定。比如,当通过射频单元101接收到某一应用程序的消息通知时,处理器110可以控制将该消息通知显示在显示面板1061的某一预设区域内,该预设区域与触控面板1071的某一区域对应,通过对触控面板1071某一区域进行触控操作,可以对显示面板1061上对应区域内显示的消息通知进行控制。
接口单元108用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。接口单元108可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端100和外部装置之间传输数据。
存储器109可用于存储软件程序以及各种数据。存储器109可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据手机的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器109可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
处理器110是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监控。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。
移动终端100还可以包括给各个部件供电的电源111(比如电池),优选的,电源111可以通过电源管理系统与处理器110逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。
尽管图1未示出,移动终端100还可以包括蓝牙模块等,在此不再赘述。
为了便于理解本发明实施例,下面对本发明的移动终端所基于的通信网络系统进行描述。
请参阅图2,图2为本发明实施例提供的一种通信网络系统架构图,该通信网络系统为通用移动通信技术的LTE系统,该LTE系统包括依次通讯连接的UE(User Equipment,用户设备)201,E-UTRAN(Evolved UMTS Terrestrial Radio Access Network,演进式UMTS陆地无线接入网)202,EPC(Evolved Packet Core,演进式分组核心网)203和运营商的IP业务204。
具体地,UE201可以是上述终端100,此处不再赘述。
E-UTRAN202包括eNodeB2021和其它eNodeB2022等。其中,eNodeB2021可以通过回程(backhaul)(例如X2接口)与其它eNodeB2022连接,UE201与eNodeB2021连接后,可以接收到由eNodeB2021发送的通知消息通知,eNodeB2021可以连接到EPC203,eNodeB2021可以提供UE201到EPC203的接入。
EPC203可以包括MME(Mobility Management Entity,移动性管理实体)2031,HSS(Home Subscriber Server,归属用户服务器)2032,其它MME2033,SGW(Serving Gate Way,服务网关)2034,PGW(PDN Gate Way,分组数据网络网关)2035和PCRF(Policy andCharging Rules Function,政策和资费功能实体)2036等。其中,MME2031是处理UE201和EPC203之间信令的控制节点,提供承载和连接管理。HSS2032用于提供一些寄存器来管理诸如归属位置寄存器(图中未示)之类的功能,并且保存有一些有关服务特征、数据速率等用户专用的信息。所有用户数据都可以通过SGW2034进行发送,PGW2035可以提供UE 201的IP地址分配以及其它功能,PCRF2036是业务数据流和IP承载资源的策略与计费控制策略决策点,它为策略与计费执行功能单元(图中未示)选择及提供可用的策略和计费控制决策。
IP业务204可以包括因特网、内联网、IMS(IP Multimedia Subsystem,IP多媒体子系统)或其它IP业务等。
虽然上述以LTE系统为例进行了介绍,但本领域技术人员应当知晓,本发明不仅仅适用于LTE系统,也可以适用于其他无线通信系统,例如GSM、CDMA2000、WCDMA、TD-SCDMA以及未来新的网络系统等,此处不做限定。
基于上述移动终端硬件结构以及通信网络系统,提出本发明各个实施例。
第一实施例
为了解决现有技术中没有完善的内存泄漏检测方案,导致内存泄漏后很难定位并解决,大大增加了软件开发难度的问题。本实施例提供一种内存泄露检测方法,该内存泄露检测方法通过对终端上各应用内存申请和释放进行监控,当应用进行内存申请时,记录应用的内存申请信息,当应用进行内存释放时,记录应用的内存释放信息,进一步地,显示内存申请信息与内存释放信息。具体参见图3所示,图3为本实施例提供的内存泄露检测方法的基本流程图:
S301:对终端上各应用内存申请和释放进行监控,当应用进行内存申请时,记录应用的内存申请信息,当应用进行内存释放时,记录应用的内存释放信息。
本实施例中的内存申请信息包括:内存申请大小、内存申请位置以及调用栈信息;其中内存申请位置包括堆位置、栈位置等,调用栈信息包括backtrace信息,即原始路径信息;本实施例中的内存释放信息包括:内存释放大小、内存释放位置。值得注意的是,这里所列举的只是常见的内存申请信息和内存释放信息,在此基础上,内存申请信息和内存释放信息还可以包括其他任意的信息,本发明对此不做具体限定。
本实施例中对终端上各应用内存申请和释放进行监控,具体的,对内存调用和释放函数进行监控,例如调用函数malloc、calloc、释放函数free等。
应当理解的是,本实施例中的终端上各应用可以是终端上安装的所有应用,也可以终端上安装的部分应用或终端上安装的任意应用,尤其针对于运行时占用内存较多的应用。
可选地,本实施例中记录应用的内存申请与释放信息之前,还包括:当应用开始运行时,为其分配预设大小的内存,以用于存储内存申请信息和应用进行内存释放时的内存释放信息。
为了更好的理解,这里以一个示例进行说明:
例如,malloc_debug可以采用“malloc钩”技术,将调用函数malloc、calloc、释放函数free等函数覆盖成debug_malloc、debug_calloc、debug_free等函数,这些函数会被系统回调,在这些函数中,为其分配额外的内存,以用于存储内存申请信息和内存释放信息。
S302:显示内存申请信息与内存释放信息。
可选地,本实施例中显示内存申请信息与内存释放信息之前,包括至少以下两种情况:
情况一,具体参见图4所示:
S401:根据内存申请信息与内存释放信息统计内存泄露大小。
应当理解的是,本实施例中可根据内存申请信息与内存释放信息统计内存泄露大小,进而在内存泄露大小超过预设阈值时,显示内存申请信息与内存释放信息。
可选地,本实施例中根据内存申请信息与内存释放信息统计内存泄露大小,包括至少以下步骤,具体参见图5所示:
S501:从内存申请信息中确定出内存申请的总大小。
为了更好的理解,这里以一个具体示例进行说明:
例如,参见表一所示,记录的应用K进行内存申请的内存申请信息。
表一
内存申请时间点 内存申请大小 内存申请位置 调用栈信息
a1 b1 c1 d1
a2 b2 c2 d2
a3 b3 c3 d3
a4 b4 c4 d4
a5 b5 c5 d5
由上述表一可知,应用K进行了5次的内存申请,其内存申请大小分别为b1、b2、b3、b4、b5,因此内存申请的总大小为b1+b2+b3+b4+b5。
S502:从内存释放信息中确定出内存释放的总大小。
同样的,参见表二所示,记录的应用K进行内存释放的内存释放信息。
表二
内存释放时间点 内存释放大小 内存释放位置
a11 b11 c11
a21 b21 c21
a31 b31 c31
a41 b41 c41
由上述表二可知,应用K进行了4次的内存释放,其内存释放大小分别为b11、b21、b31、b41、b51,因此内存释放的总大小为b11+b21+b31+b41。
S503:根据内存申请的总大小与内存释放的总大小计算内存泄露大小。
承接上例,进一步地,根据内存申请的总大小b1+b2+b3+b4+b5和内存释放的总大小b11+b21+b31+b41计算内存泄露大小,设计算得到的内存泄露大小为B1。
S402:判断内存泄露大小是否超过预设阈值;
若是,执行S403,若否,则结束此次流程。
承接上例,进一步地,设内存泄露大小B1超过了预设阈值B,此时需执行S403。
应当理解的是,在内存泄露大小B1未超过预设阈值B时,则结束此次流程。
值得注意的是,在实际应用中,预设阈值由开发人员根据实验或经验进行灵活设置,还值得注意的是,上述所列举的只是一个具体示例,在实际应用中,需根据具体应用场景做灵活调整。
S403:显示内存申请信息与内存释放信息。
承接上例,进一步地,显示应用K的内存申请信息与内存释放信息。
可选地,本实施例中显示内存申请信息与内存释放信息,包括:将内存申请信息与内存释放信息写入至日志文件中,并显示日志文件。
应当理解的是,本实施例中malloc_debug可以通过log系统打印出内存泄漏信息,即将内存申请信息与内存释放信息写入至日志文件,后续开发人员便可查看日志文件中具体的内存申请信息与内存释放信息,排查和定位应用内存泄漏。
可选地,本实施例中在显示日志文件之前,还包括发出告警通知信息,以更好的通知开发人员已存在内存泄露,提示其进行日志文件的查看;对于发出告警通知信息包括但不限于响铃、振动、应用消息通知等方式,对此本发明不做具体限定,在实际应用中,可根据具体应用场景做灵活调整。
情况二,具体参见图6所示:
S601:在应用的运行过程中,对应用占用的内存大小进行周期性采样得到预设时间段内的采样数据。
在本实施例中,还可以在应用的运行过程中,对应用占用的内存大小进行周期性采样得到预设时间段内的采样数据,进而根据采样数据生成内存占用曲线图,在内存占用曲线图走势为递增走势时,显示内存申请信息与内存释放信息。
S602:根据采样数据生成内存占用曲线图。
可以理解的是,在应用运行过程中,其占用的内存大小具有一定的波动性,在应用运行初期,其占用的内存大小可能并不大,随着运行时间的增加其占用的内存大小逐步增加,在运行一段时间后,峰值达到相对平稳的状态时便不再明显增加;在应用正常运行过程中,其会不断地占用内存,并释放不再使用的内存,随着运行时长的不断增加,应用占用的内存大小不会有明显的增长,而是忽高忽低的正常波动。
因此,如果在应用运行一段时间后进行周期采样获得的预设时间段内的采样数据,基于该采样数据生成的内存占用曲线图的走势为平稳趋势,则说明应用运行正常,无内存泄露;如果在应用刚开始运行时即进行周期采样获得预设时间段内的采样数据,基于该采样数据生成的内存占用曲线图的走势为峰值稳定趋势,则说明应用运行正常,无内存泄露;而在应用运行过程中,如果内存没有被正常释放,就会导致其占用的内存大小不断增长,内存占用曲线图的走势表现为一直递增趋势,在这种情况下,可以确定应用存在内存泄露的情况。
为了更好的理解,这里以一个具体示例进行说明:
例如,设对应用K占用的内存大小进行周期性采样得到预设时间段内的采样数据,由根据采样数据生成内存占用曲线图如图7所示,其中横坐标为采样时刻T,纵坐标为内存占用大小C。
S603:判断内存占用曲线图走势是否为递增走势;
若是,执行S604,若否,则结束此次流程。
承接上例,进一步地,明显的,图7所示的内存占用曲线图走势为递增走势,此时执行S604。
S604:判定当前处于内存泄露,显示内存申请信息与内存释放信息。
承接上例,进一步地,判定当前处于内存泄露,显示应用K的内存申请信息与内存释放信息,同时还可将图7所示的曲线图进行显示,以便开发人员结合两者可更加直观地查看到应用K的内存泄漏情况。
本实施例提供的内存泄露检测方法,通过对终端上各应用内存申请和释放进行监控,当应用进行内存申请时,记录应用的内存申请信息,当应用进行内存释放时,记录应用的内存释放信息,进一步地,显示内存申请信息与内存释放信息;解决了现有技术中没有完善的内存泄漏检测方案,导致内存泄漏后很难定位并解决,大大增加了软件开发难度的问题。也即在本实施例中,对终端上各应用内存申请和释放时的内存申请信息和内存释放信息进行了记录,且在内存泄露大小超过预设阈值时,将内存申请信息与内存释放信息写入至日志文件中,后续开发人员可以通过查看对应的日志文件,排查和定位应用内存泄漏,避免了内存泄露后难以定位的现象发生,大大降低了软件开发难度,为开发人员带来诸多便利。
第二实施例
本实施例是在第一实施例的基础上,以一种具体的内存泄露检测方法为例对本发明作进一步地示例说明,具体参见图8所示:
S801:对终端上各应用内存申请和释放进行监控,当应用进行内存申请时,记录应用的内存申请信息,当应用进行内存释放时,记录应用的内存释放信息。
设对终端上安装的各应用均进行内存申请和释放的监控,其中为了方便描述,本实施例仅以对应用Q内存申请和释放进行监控的过程为例进行说明,其他应用类似;其中记录的应用Q内存申请信息包括内存申请大小、内存申请位置以及调用栈信息,内存释放信息包括内存释放大小、内存释放位置。
S802:根据内存申请信息与内存释放信息统计内存泄露大小。
承接上例,进一步地,设根据内存申请信息与内存释放信息统计得到内存泄露大小为B1。
S803:判断内存泄露大小是否超过预设阈值;
若是,执行S804,若否,结束此次流程。
承接上例,进一步地,设内存泄露大小B1超过了预设阈值B,此时需执行S804。
可以理解的是,在内存泄露大小B1未超过预设阈值B时,结束此次流程。
S804:将内存申请信息与内存释放信息写入至日志文件中,并显示日志文件。
承接上例,进一步地,将应用Q的内存申请信息与内存释放信息写入至日志文件中,并显示日志文件,以供开发人员通过查看日志文件,排查和定位应用内存泄漏。
本实施例提供的内存泄露检测方法,通过通过对终端上各应用内存申请和释放进行监控,当应用进行内存申请时,记录应用的内存申请信息,当应用进行内存释放时,记录应用的内存释放信息,进一步地,显示内存申请信息与内存释放信息;解决了现有技术中没有完善的内存泄漏检测方案,导致内存泄漏后很难定位并解决,大大增加了软件开发难度的问题。也即本实施例中的内存泄露检测方法实现了应用内存泄漏的快速排查和定位,大大降低了软件开发难度,为开发人员带来诸多便利。
第三实施例
本实施例提供一种终端,请参见图9所示,本实施例提供的终端包括处理器901、存储器902、及通信总线903。
其中,本实施例中的通信总线903用于实现处理器901与存储器902之间的连接通信,处理器901则用于执行存储器902中存储的一个或者多个程序,以实现以下步骤:
对终端上各应用内存申请和释放进行监控,当应用进行内存申请时,记录应用的内存申请信息,当应用进行内存释放时,记录应用的内存释放信息;
显示内存申请信息与内存释放信息。
本实施例中的内存申请信息包括:内存申请大小、内存申请位置以及调用栈信息;其中内存申请位置包括堆位置、栈位置等,调用栈信息包括backtrace信息,即原始路径信息;本实施例中的内存释放信息包括:内存释放大小、内存释放位置。值得注意的是,这里所列举的只是常见的内存申请信息和内存释放信息,在此基础上,内存申请信息和内存释放信息还可以包括其他任意的信息,本发明对此不做具体限定。
本实施例中对终端上各应用内存申请和释放进行监控,具体的,对内存调用和释放函数进行监控,例如调用函数malloc、calloc、释放函数free等。
应当理解的是,本实施例中的终端上各应用可以是终端上安装的所有应用,也可以终端上安装的部分应用或终端上安装的任意应用,尤其针对于运行时占用内存较多的应用。
可选地,本实施例中处理器901记录应用的内存申请与释放信息之前,还包括执行至少以下步骤:
当应用开始运行时,为其分配预设大小的内存,以用于存储内存申请信息和应用进行内存释放时的内存释放信息。
可选地,本实施例中处理器901显示内存申请信息与内存释放信息之前,包括至少以下两种情况:
情况一,处理器901执行至少以下步骤:
根据内存申请信息与内存释放信息统计内存泄露大小;
判断内存泄露大小是否超过预设阈值;
若是,显示内存申请信息与内存释放信息。
可选地,本实施例中处理器901根据内存申请信息与内存释放信息统计内存泄露大小,执行至少以下步骤:
从内存申请信息中确定出内存申请的总大小;
从内存释放信息中确定出内存释放的总大小;
根据内存申请的总大小与内存释放的总大小计算内存泄露大小。
情况二,处理器901执行至少以下步骤:
在应用的运行过程中,对应用占用的内存大小进行周期性采样得到预设时间段内的采样数据;
根据采样数据生成内存占用曲线图;
判断内存占用曲线图走势是否为递增走势;
若是,判定当前处于内存泄露,显示内存申请信息与内存释放信息。
可以理解的是,在应用运行过程中,其占用的内存大小具有一定的波动性,在应用运行初期,其占用的内存大小可能并不大,随着运行时间的增加其占用的内存大小逐步增加,在运行一段时间后,峰值达到相对平稳的状态时便不再明显增加;在应用正常运行过程中,其会不断地占用内存,并释放不再使用的内存,随着运行时长的不断增加,应用占用的内存大小不会有明显的增长,而是忽高忽低的正常波动。
因此,如果在应用运行一段时间后进行周期采样获得的预设时间段内的采样数据,基于该采样数据生成的内存占用曲线图的走势为平稳趋势,则说明应用运行正常,无内存泄露;如果在应用刚开始运行时即进行周期采样获得预设时间段内的采样数据,基于该采样数据生成的内存占用曲线图的走势为峰值稳定趋势,则说明应用运行正常,无内存泄露;而在应用运行过程中,如果内存没有被正常释放,就会导致其占用的内存大小不断增长,内存占用曲线图的走势表现为一直递增趋势,在这种情况下,可以确定应用存在内存泄露的情况。
可选地,本实施例中处理器901显示内存申请信息与内存释放信息,包括:将内存申请信息与内存释放信息写入至日志文件中,并显示日志文件。
应当理解的是,本实施例中malloc_debug可以通过log系统打印出内存泄漏信息,即将内存申请信息与内存释放信息写入至日志文件,后续开发人员便可查看日志文件中具体的内存申请信息与内存释放信息,排查和定位应用内存泄漏。
可选地,本实施例中在处理器901显示日志文件之前,还包括发出告警通知信息,以更好的通知开发人员已存在内存泄露,提示其进行日志文件的查看;对于发出告警通知信息包括但不限于响铃、振动、应用消息通知等方式,对此本发明不做具体限定,在实际应用中,可根据具体应用场景做灵活调整。
值得注意的是,为了不累赘说明,在本实施例中并未完全阐述实施例一、二中的所有示例,应当明确的是,实施例一、二中的所有示例均适用于本实施例。
本实施例还提供一种计算机可读存储介质,计算机可读存储介质存储有一个或者多个程序,一个或者多个程序可被一个或者多个处理器执行,以实现如上述的内存泄露检测方法的步骤。
本实施例提供的终端和计算机可读存储介质通过对终端上各应用内存申请和释放进行监控,当应用进行内存申请时,记录应用的内存申请信息,当应用进行内存释放时,记录应用的内存释放信息,进一步地,显示内存申请信息与内存释放信息;解决了现有技术中没有完善的内存泄漏检测方案,导致内存泄漏后很难定位并解决,大大增加了软件开发难度的问题。所以和现有技术相比,本实施例提供的终端和计算机可读存储介质,对终端上各应用内存申请和释放时的内存申请信息和内存释放信息进行了记录,且在内存泄露大小超过预设阈值时,将内存申请信息与内存释放信息写入至日志文件中,后续开发人员可以通过查看对应的日志文件,排查和定位应用内存泄漏,避免了内存泄露后难以定位的现象发生,大大降低了软件开发难度,为开发人员带来诸多便利。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
上面结合附图对本发明的实施例进行了描述,但是本发明并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本发明的启示下,在不脱离本发明宗旨和权利要求所保护的范围情况下,还可做出很多形式,这些均属于本发明的保护之内。

Claims (10)

1.一种内存泄露检测方法,其特征在于,所述内存泄露检测方法包括:
对终端上各应用内存申请和释放进行监控,当所述应用进行内存申请时,记录所述应用的内存申请信息,当所述应用进行内存释放时,记录所述应用的内存释放信息;
显示所述内存申请信息与内存释放信息。
2.如权利要求1所述的内存泄露检测方法,其特征在于,所述内存申请信息包括:内存申请大小、内存申请位置以及调用栈信息;
所述内存释放信息包括:内存释放大小、内存释放位置。
3.如权利要求2所述的内存泄露检测方法,其特征在于,所述显示所述内存申请信息与内存释放信息之前,还包括:
根据所述内存申请信息与内存释放信息统计内存泄露大小;
判断所述内存泄露大小是否超过预设阈值;
若是,显示所述内存申请信息与内存释放信息。
4.如权利要求3所述的内存泄露检测方法,其特征在于,所述根据所述内存申请信息与内存释放信息统计内存泄露大小,包括:
从所述内存申请信息中确定出内存申请的总大小;
从所述内存释放信息中确定出内存释放的总大小;
根据所述内存申请的总大小与所述内存释放的总大小计算内存泄露大小。
5.如权利要求1所述的内存泄露检测方法,其特征在于,所述显示所述内存申请信息与内存释放信息之前,还包括:
在所述应用的运行过程中,对所述应用占用的内存大小进行周期性采样得到预设时间段内的采样数据;
根据所述采样数据生成内存占用曲线图;
判断所述内存占用曲线图走势是否为递增走势;
若是,判定所述终端当前处于内存泄露,显示所述内存申请信息与内存释放信息。
6.如权利要求1-5任一项所述的内存泄露检测方法,其特征在于,记录所述应用的内存申请信息与释放信息之前,还包括:
当所述应用开始运行时,为其分配预设大小的内存,以用于存储内存申请信息和应用进行内存释放时的内存释放信息。
7.如权利要求1-5任一项所述的内存泄露检测方法,其特征在于,所述显示所述内存申请信息与内存释放信息,包括:
将所述内存申请信息与内存释放信息写入至日志文件中,并显示所述日志文件。
8.如权利要求7所述的内存泄露检测方法,其特征在于,所述显示所述日志文件之前,还包括:发出告警通知信息。
9.一种终端,其特征在于,所述终端包括处理器、存储器及通信总线;
所述通信总线用于实现所述处理器和所述存储器之间的连接通信;
所述处理器用于执行所述存储器中存储的一个或者多个程序,以实现如权利要求1-8任一项所述的内存泄露检测方法的步骤。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现如权利要求1-8任一项所述的内存泄露检测方法的步骤。
CN201910797482.0A 2019-08-27 2019-08-27 一种内存泄露检测方法、终端及计算机可读存储介质 Pending CN110704217A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201910797482.0A CN110704217A (zh) 2019-08-27 2019-08-27 一种内存泄露检测方法、终端及计算机可读存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201910797482.0A CN110704217A (zh) 2019-08-27 2019-08-27 一种内存泄露检测方法、终端及计算机可读存储介质

Publications (1)

Publication Number Publication Date
CN110704217A true CN110704217A (zh) 2020-01-17

Family

ID=69193635

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201910797482.0A Pending CN110704217A (zh) 2019-08-27 2019-08-27 一种内存泄露检测方法、终端及计算机可读存储介质

Country Status (1)

Country Link
CN (1) CN110704217A (zh)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111309507A (zh) * 2020-02-13 2020-06-19 支付宝(杭州)信息技术有限公司 内存泄露的检测方法、装置和机器可读存储介质
CN111966603A (zh) * 2020-09-04 2020-11-20 网易(杭州)网络有限公司 内存泄露的检测方法及装置、可读存储介质及电子设备
CN111984496A (zh) * 2020-07-16 2020-11-24 北京字节跳动网络技术有限公司 一种监控栈内存泄露的方法、装置、介质和电子设备
CN111984541A (zh) * 2020-08-31 2020-11-24 北京达佳互联信息技术有限公司 一种内存泄漏检测方法及装置、终端
CN113326120A (zh) * 2020-02-29 2021-08-31 杭州迪普科技股份有限公司 管理内存的装置和方法
CN113434364A (zh) * 2021-06-25 2021-09-24 青岛海尔科技有限公司 屏端设备内存检测方法、装置、存储介质及电子装置
CN114546590A (zh) * 2022-02-18 2022-05-27 北京基调网络股份有限公司 Java虚拟机堆内存集合对象监测方法及内存溢出分析方法
CN116680161A (zh) * 2022-10-10 2023-09-01 荣耀终端有限公司 内存泄漏检测方法、可读介质和电子设备

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101539870A (zh) * 2008-03-21 2009-09-23 中兴通讯股份有限公司 内存泄漏检测装置及方法
WO2010043176A1 (zh) * 2008-10-17 2010-04-22 华为技术有限公司 内存泄漏的检测方法和装置
CN102681938A (zh) * 2012-05-15 2012-09-19 青岛海信移动通信技术股份有限公司 一种内存泄漏检测方法及装置
CN104866409A (zh) * 2015-05-29 2015-08-26 小米科技有限责任公司 内存泄露监控方法和装置
CN107346285A (zh) * 2017-05-26 2017-11-14 郑州云海信息技术有限公司 一种内存泄露检测方法及装置

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN101539870A (zh) * 2008-03-21 2009-09-23 中兴通讯股份有限公司 内存泄漏检测装置及方法
WO2010043176A1 (zh) * 2008-10-17 2010-04-22 华为技术有限公司 内存泄漏的检测方法和装置
CN102681938A (zh) * 2012-05-15 2012-09-19 青岛海信移动通信技术股份有限公司 一种内存泄漏检测方法及装置
CN104866409A (zh) * 2015-05-29 2015-08-26 小米科技有限责任公司 内存泄露监控方法和装置
CN107346285A (zh) * 2017-05-26 2017-11-14 郑州云海信息技术有限公司 一种内存泄露检测方法及装置

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN111309507B (zh) * 2020-02-13 2022-05-10 支付宝(杭州)信息技术有限公司 内存泄露的检测方法、装置和机器可读存储介质
CN111309507A (zh) * 2020-02-13 2020-06-19 支付宝(杭州)信息技术有限公司 内存泄露的检测方法、装置和机器可读存储介质
CN113326120B (zh) * 2020-02-29 2023-12-26 杭州迪普科技股份有限公司 管理内存的装置和方法
CN113326120A (zh) * 2020-02-29 2021-08-31 杭州迪普科技股份有限公司 管理内存的装置和方法
CN111984496A (zh) * 2020-07-16 2020-11-24 北京字节跳动网络技术有限公司 一种监控栈内存泄露的方法、装置、介质和电子设备
CN111984496B (zh) * 2020-07-16 2024-04-16 北京字节跳动网络技术有限公司 一种监控栈内存泄露的方法、装置、介质和电子设备
CN111984541A (zh) * 2020-08-31 2020-11-24 北京达佳互联信息技术有限公司 一种内存泄漏检测方法及装置、终端
CN111966603A (zh) * 2020-09-04 2020-11-20 网易(杭州)网络有限公司 内存泄露的检测方法及装置、可读存储介质及电子设备
CN111966603B (zh) * 2020-09-04 2024-01-19 网易(杭州)网络有限公司 内存泄露的检测方法及装置、可读存储介质及电子设备
CN113434364A (zh) * 2021-06-25 2021-09-24 青岛海尔科技有限公司 屏端设备内存检测方法、装置、存储介质及电子装置
CN113434364B (zh) * 2021-06-25 2024-03-22 青岛海尔科技有限公司 屏端设备内存检测方法、装置、存储介质及电子装置
CN114546590A (zh) * 2022-02-18 2022-05-27 北京基调网络股份有限公司 Java虚拟机堆内存集合对象监测方法及内存溢出分析方法
CN116680161A (zh) * 2022-10-10 2023-09-01 荣耀终端有限公司 内存泄漏检测方法、可读介质和电子设备
CN116680161B (zh) * 2022-10-10 2024-06-07 荣耀终端有限公司 内存泄漏检测方法、可读介质和电子设备

Similar Documents

Publication Publication Date Title
CN110704217A (zh) 一种内存泄露检测方法、终端及计算机可读存储介质
CN107027114A (zh) 一种sim卡切换方法、设备及计算机可读存储介质
CN112799577B (zh) 一种小窗投屏的方法、终端及存储介质
CN110007816B (zh) 一种显示区域确定方法、终端及计算机可读存储介质
CN109766119B (zh) 恢复分区升级方法、终端和计算机可读存储介质
CN112822538A (zh) 投屏显示方法、投屏方法、投屏设备、终端及存储介质
CN108307030A (zh) 一种sim卡管理方法、设备及计算机可读存储介质
CN108377292B (zh) 解决内存泄露的方法、终端、服务器及计算机存储介质
CN112597115A (zh) 容器镜像的压缩方法、装置、终端设备及介质
CN110955397A (zh) 游戏终端帧率的设置方法、游戏终端及存储介质
CN112347067B (zh) 一种日志信息管控方法、设备及计算机可读存储介质
CN107678622B (zh) 一种应用图标的显示方法、终端及存储介质
CN111381762A (zh) 一种双屏切换方法、设备及计算机可读存储介质
CN112395106A (zh) 进程管理方法、移动终端以及计算机可读存储介质
CN111970738A (zh) 一种网络切换控制方法、设备及计算机可读存储介质
CN109684020B (zh) 一种主题切换方法、设备及计算机可读存储介质
CN108364595B (zh) 一种静电释放检测方法、移动终端及计算机可读存储介质
CN109151201B (zh) 一种防沉迷方法、移动终端以及计算机存储介质
CN109062688B (zh) 一种内存分配方法、服务器及移动终端
CN108667714B (zh) 信息的发送方法、接收方法、移动终端及存储介质
CN110647418A (zh) 异常处理方法、服务器及移动终端
CN115278842A (zh) 移动终端投屏方法、移动终端及存储介质
CN113485667A (zh) 一种终端投屏显示的方法、终端及存储介质
CN109379719B (zh) 一种应用程序广播处理方法、设备及计算机可读存储介质
CN109739676B (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
RJ01 Rejection of invention patent application after publication
RJ01 Rejection of invention patent application after publication

Application publication date: 20200117