CN108377292A - 解决内存泄露的方法、终端、服务器及计算机存储介质 - Google Patents

解决内存泄露的方法、终端、服务器及计算机存储介质 Download PDF

Info

Publication number
CN108377292A
CN108377292A CN201810092448.9A CN201810092448A CN108377292A CN 108377292 A CN108377292 A CN 108377292A CN 201810092448 A CN201810092448 A CN 201810092448A CN 108377292 A CN108377292 A CN 108377292A
Authority
CN
China
Prior art keywords
memory
server
application program
ram leakage
terminal
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
CN201810092448.9A
Other languages
English (en)
Other versions
CN108377292B (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.)
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 CN201810092448.9A priority Critical patent/CN108377292B/zh
Publication of CN108377292A publication Critical patent/CN108377292A/zh
Application granted granted Critical
Publication of CN108377292B publication Critical patent/CN108377292B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/55Push-based network services
    • 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/0793Remedial or corrective actions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L43/00Arrangements for monitoring or testing data switching networks
    • H04L43/16Threshold monitoring
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M1/00Substation equipment, e.g. for use by subscribers
    • H04M1/72Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
    • H04M1/724User interfaces specially adapted for cordless or mobile telephones
    • H04M1/72448User interfaces specially adapted for cordless or mobile telephones with means for adapting the functionality of the device according to specific conditions
    • H04M1/72454User interfaces specially adapted for cordless or mobile telephones with means for adapting the functionality of the device according to specific conditions according to context-related or environment-related conditions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W52/00Power management, e.g. TPC [Transmission Power Control], power saving or power classes
    • H04W52/02Power saving arrangements
    • H04W52/0209Power saving arrangements in terminal devices
    • YGENERAL 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
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D30/00Reducing energy consumption in communication networks
    • Y02D30/70Reducing energy consumption in communication networks in wireless communication networks

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Theoretical Computer Science (AREA)
  • Quality & Reliability (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Environmental & Geological Engineering (AREA)
  • Human Computer Interaction (AREA)
  • Mobile Radio Communication Systems (AREA)
  • Telephone Function (AREA)

Abstract

本发明公开了一种解决内存泄露的方法、终端、服务器及计算机存储介质,该方法包括:记录每一个应用程序的方法生成的内存空间的大小并上传至服务器;对内存空间进行监控,监控内存是否发生泄露;当发生内存泄露,对导致内存泄露的方法进行分析;将导致内存泄露的方法的分析结果上报给服务器;接收服务器推送的修改后的方法包文件,替换该方法包文件。本发明在系统不升级的状态下就能解决内存泄露的问题,并提高应用程序的运行流畅度,降低手机功耗。

Description

解决内存泄露的方法、终端、服务器及计算机存储介质
【技术领域】
本发明涉及通信技术领域,尤其涉及一种解决内存泄露的方法、终端、服务器及计算机存储介质。
【背景技术】
安卓操作系统中的应用都是java实现的,基于JVM虚拟机。其内存回收机制采用非定时任务触发的方式。当发生内存泄露时,系统会频繁触发内存回收。这时候,CPU的占用率就会急剧上升。
该方案存在的问题:内存回收频繁触发,导致CPU占用率急剧上升;统会出现卡顿;应用无法正常使用;解决该泄露问题需要对应用进行版本升级,严重影响用户体验。如何解决以上问题,提升用户体验是亟待解决的问题。
【发明内容】
针对上述缺陷,本发明提供了解决内存泄露的方法、终端、服务器及计算机存储介质,以解决上述技术问题。
首先,为实现上述目的,本发明提出一种解决内存泄露的方法,应用于终端,所述方法包文件括:
记录每一个应用程序的方法生成的内存空间的大小并上传至服务器;
对所述内存空间进行监控,监控所述内存空间是否发生内存泄露;
当所述内存空间发生内存泄露时,对导致内存泄露的所述应用程序的方法进行分析;
将所述方法的分析结果上报给所述服务器;
接收所述服务器推送的修改后的方法包文件,并使用所述方法包文件替换所述导致内存泄露的应用程序的方法对应的方法包文件。
可选地,所述的解决内存泄露的方法,还接收所述服务器推送的所述每一个应用程序的方法生成的内存空间大小的阈值;当监控到所述应用程序的方法生成的内存空间大小超过所述阈值时,认为所述应用程序的方法发生内存泄漏。
可选地,所述的解决内存泄露的方法,当发生内存泄露后,降低所述导致内存泄露的应用程序的方法的运行频率并将所述方法生成的数据写入磁盘。
可选地,所述的解决内存泄露的方法,替换所述应用程序的方法包文件后,取消对所述方法的降频处理并将所述应用程序的方法生成的数据写入内存。
此外,为实现上述目的,本发明还提供一种解决内存泄露的方法,应用于服务器,所述方法包文件括:
接收终端上传的每一个应用中所有方法生成的内存空间的大小,并进行统计分析;
接收终端上传的每一个应用程序的所有方法生成的内存空间大小,并进行统计分析;
接收所述终端上传的存在内存泄漏的方法信息,发送解决内存泄漏问题的通知信息给相关人员;
保存解决内存泄漏问题的方法包文件,然后将所述解决内存泄漏问题的方法包文件推送给所述终端。
可选地,所述的解决内存泄露的方法,给所述每一个应用程序的所有方法生成的内存空间大小设置一个阈值,然后把所述阈值推送给所述终端。
可选地,所述服务器自动获取最新提交的代码,对所述最新提交的代码及所述存在内存泄漏的方法生成一个方法包文件。
此外,为实现上述目的,本发明还提供一种终端,包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的至少一个计算机程序,所述至少一个计算机程序被所述处理器执行时实现本发明实施例提供的解决内存泄露的方法中的步骤。
此外,为实现上述目的,本发明还提供一种服务器,包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的至少一个计算机程序,所述至少一个计算机程序被所述处理器执行时实现本发明实施例提供的解决内存泄露的方法中的步骤。
此外,为实现上述目的,本发明还提供一种计算机可读存储介质,所述计算机可读存储介质存储有计算机可执行的至少一个程序,其特征在于,所述至少一个程序被所述计算机执行时使所述计算机执行实现本发明实施例提供的解决内存泄露的方法中的步骤。
本发明的有益效果:本发明根据服务器统计的各个应用方法生成的内存空间的大小及设定阈值,及时监控可能存在的内存泄露方法,采取降低方法运行频率和内存数据生成定位到磁盘的办法暂时解决泄露问题,并将方法调用链上报给服务器进行解决,解决后通过代码包的形式推送给手机,保证不升级就能解决内存泄露的问题,从而能定位解决大部分的内存泄露问题,并提高应用程序的运行流畅度,降低手机功耗。
【附图说明】
图1为实现本发明各个实施例的移动终端的硬件结构示意图。
图2为如图1所示的移动终端的无线通信系统示意图。
图3是本发明提供的解决内存泄露的方法实施例一的方法流程图。
图4是本发明提供的解决内存泄露的方法实施例二的方法流程图。
图5是本发明提供的解决内存泄露的设备实施例三的模块图。
图6是本发明提供的解决内存泄露的方法实施例五的方法流程图。
图7是本发明提供的解决内存泄露的服务器实施例六的模块图。
【具体实施方式】
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。
终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(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可用于收发信息或通话过程中,信号的接收和发送,具体的,将基站的下行信息接收后,给处理器110处理;另外,将上行的数据发送给基站。通常,射频单元101包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器、双工器等。此外,射频单元101还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于GSM(Global System of Mobile communication,全球移动通讯系统)、GPRS(General Packet Radio Service,通用分组无线服务)、CDMA2000(CodeDivision Multiple Access 2000,码分多址2000)、WCDMA(Wideband Code DivisionMultiple Access,宽带码分多址)、TD-SCDMA(Time Division-Synchronous CodeDivision Multiple Access,时分同步码分多址)、FDD-LTE(Frequency DivisionDuplexing-Long Term Evolution,频分双工长期演进)和TDD-LTE(Time DivisionDuplexing-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集成而实现移动终端的输入和输出功能,具体此处不做限定。
接口单元108用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。接口单元108可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端100和外部装置之间传输数据。
存储器109可用于存储软件程序以及各种数据。存储器109可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据手机的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器109可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
处理器110是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监控。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。
拍摄单元112用于拍摄照片或视频,拍摄后的照片或视频存储于存储器109。拍摄后的照片或视频,可以在显示单元106进行显示。
移动终端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连接,eNodeB2021连接到EPC203,eNodeB2021可以提供UE201到EPC203的接入。
EPC203可以包括MME(Mobility Management Entity,移动性管理实体)2031,HSS(Home Subscriber Server,归属用户服务器)2032,其它MME2033,SGW(Serving GateWay,服务网关)2034,PGW(PDN GateWay,分组数据网络网关)2035和PCRF(Policy and ChargingRules 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,一种解决内存泄露的方法,所述解决内存泄露的方法应用于一终端中,包括:
S101、终端记录每一个应用程序的方法生成的内存空间的大小并上传至服务器。
终端记录每一个应用程序中所有方法在运行过程中生成的内存空间的大小,并上传给服务器。终端上传给服务器的信息包括:应用程序名称、应用程序中每一个方法的名称、每个一个方法生成的内存空间的大小。例如应用程序A,有3个方法,分别为方法1、2、3,在某次运行过程中生成的内存空间的大小分别是100字节、1000字节和260字节。终端记录该应用程序所有方法在运行过程中生成的内存空间大小等信息,并将这些信息上报到服务器,由服务器进行汇总,进而分析到每一个应用各个方法生成的内存空间的大小值。由此可以统计出每一个方法在运行过程中生成过的最大内存空间的大小,例如应用A的方法1,记录的最大内存大小为2000字节。针对内存泄露问题,服务器侧还可以设定一个阈值,表示最大内存大小的倍数,例如5。这就表示当应用A的方法1运行过程中,如果生产的内存大小超过最大值的5倍,就认为它可能存在内存泄露。服务器将该应用程序的方法生成内存空间的大小的阈值发给终端,终端保存这些数据。
S102、终端对内存空间进行监控,监控内存是否发生泄露。
终端设置一个对内存空间进行监控的监控程序,监控所有应用程序的内存是否发生泄露。该监控程序会监控到应用程序调用的每一个方法以及该方法生成的内存空间大小,一旦该内存空间持续增大,超出了服务器侧下发的最大内存大小的阈值倍数,就会认为该方法发生了内存泄露。
S103、当发生内存泄露,终端对导致内存泄露的方法进行分析。
S104、终端将导致内存泄露的方法的分析结果上报给服务器。
终端判断某个应用程序的方法存在内存泄漏后,终端内部对该方法进行跟踪,记录该方法的调用链,并将记录的方法的调用链信息上报给服务器。例如方法1发生了内存泄露,而该调用链是方法2->方法3->方法1。
S105、终端接收服务器推送的修改后的方法包文件,替换该方法包文件。
终端接收到服务器下发的代码包后,使用该代码包(解决内存泄漏后且编译后的文件)替换应用中原有的该代码包,从而完全修复该次内存泄露的问题。
本实施例通过本专利提出的解决内存泄露的方法,将应用程序的方法调用链上报给服务器进行解决,解决后通过方法包文件的形式推送给终端,不升级终端应用程序就能解决内存泄露的问题,提升用户体验。
实施例二
参考图4,本实施例在实施例一的基础上增加以下步骤:
S106、当发生内存泄露,终端降低该方法的运行频率并将其生成的内存数据转入磁盘。
终端检测到该应用程序的某个方法存在内存泄漏后,减少对该应用程度中存在内存携带的方法调用频率。如果无法单独减少对该方法调用频率,则减少对该应用程序的调用,从而减少对该方法的调用频率。
终端检测到该应用程序的某个方法存在内存泄漏后,对该方法生成的内存数据直接保存到磁盘,而不是申请内存空间进行保存。由于终端的磁盘空间较大,把这些内存数据保存到磁盘可以有效降低对内存空间的占用,从而避免内存泄漏时占用大量内存空间,影响整个系统的运行效率。
终端检测到该应用程序的某个方法存在内存泄漏后,系统提示用户,该应用程序存在异常,需要减少使用频率。
S107、终端替换方法包文件后,取消对该方法的降频处理并将方法生成的数据空间重新定位回内存区域。
终端收到服务器下发的应用程序中存在内存泄漏的方法对应的方法包文件(编译后的文件)后,使用服务器下发的方法包文件替换本地应用程序中对应的方法包文件(如obj文件)。替换该方法包文件后,应用程序动态加载该方法包文件;如果应用程序无法动态加载该方法包文件时,在替换该方法包文件后,应用程序需要进行重启。
终端在替换方法包文件后,判断该方法包文件不存在内存泄漏问题后,取消对该方法的降低使用频率的处理,同时把使用该方法生成的内存数据保存到内存空间,而不再保存到磁盘空间。
本实施例通过本专利提出的解决内存泄露的方法,通过降低发送内存协议的应用程序的方法的运行频率并将该方法生成的内存数据保存到磁盘的方式暂时解决泄露问题,解决后通过方法包文件的形式推送给终端,提高应用程序的运行流畅度,降低手机功耗。
实施例三
参考图5,一种解决内存泄露的设备,该设备为一种移动终端(如智能手机),包括:P106显示单元、P107用户输入单元、P110处理器、P109存储器及P108通信总线。
1)P106显示单元用于显示由用户输入的信息或提供给用户的信息;
2)P107用户输入单元用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入;
3)P108通信总线用于实现处理器和存储器之间的连接通信;
4)P109存储器用于存储程序数据;
5)P110处理器用于执行存储器中存储的解决内存泄露的程序,以实现以下步骤:
S101、终端记录每一个应用程序的方法生成的内存空间的大小并上传至服务器。
终端记录每一个应用程序中所有方法在运行过程中生成的内存空间的大小,并上传给服务器。终端上传给服务器的信息包括:应用程序名称、应用程序中每一个方法的名称、每个一个方法生成的内存空间的大小。例如应用程序A,有3个方法,分别为方法1、2、3,在某次运行过程中生成的内存空间的大小分别是100字节、1000字节和260字节。终端记录该应用程序所有方法在运行过程中生成的内存空间大小等信息,并将这些信息上报到服务器,由服务器进行汇总,进而分析到每一个应用各个方法生成的内存空间的大小值。由此可以统计出每一个方法在运行过程中生成过的最大内存空间的大小,例如应用A的方法1,记录的最大内存大小为2000字节。针对内存泄露问题,服务器侧还可以设定一个阈值,表示最大内存大小的倍数,例如5。这就表示当应用A的方法1运行过程中,如果生产的内存大小超过最大值的5倍,就认为它可能存在内存泄露。服务器将该应用程序的方法生成内存空间的大小的阈值发给终端,终端保存这些数据。
S102、终端对内存空间进行监控,监控内存是否发生泄露。
终端设置一个对内存空间进行监控的监控程序,监控所有应用程序的内存是否发生泄露。该监控程序会监控到应用程序调用的每一个方法以及该方法生成的内存空间大小,一旦该内存空间持续增大,超出了服务器侧下发的最大内存大小的阈值倍数,就会认为该方法发生了内存泄露。
S103、当发生内存泄露,终端对导致内存泄露的方法进行分析。
S104、终端将导致内存泄露的方法的分析结果上报给服务器。
终端判断某个应用程序的方法存在内存泄漏后,终端内部对该方法进行跟踪,记录该方法的调用链,并将记录的方法的调用链信息上报给服务器。例如方法1发生了内存泄露,而该调用链是方法2->方法3->方法1。
S105、终端接收服务器推送的修改后的方法包文件,替换该方法包文件。
终端接收到服务器下发的代码包后,使用该代码包(解决内存泄漏后且编译后的文件)替换应用中原有的该代码包,从而完全修复该次内存泄露的问题。
本实施例通过本专利提出的解决内存泄露方法,将应用程度的方法调用链上报给服务器进行解决,解决后通过方法包文件的形式推送给终端,不升级终端应用程序就能解决内存泄露的问题,提升用户体验。
实施例四
本实施例在实施例三的基础上,P110处理器还用于执行解决内存泄露的程序,以实现以下步骤:
S106、当发生内存泄露,终端降低该方法的运行频率并将其生成的内存数据转入磁盘。
终端检测到该应用程序的某个方法存在内存泄漏后,减少对该应用程度中存在内存携带的方法调用频率。如果无法单独减少对该方法调用频率,则减少对该应用程序的调用,从而减少对该方法的调用频率。
终端检测到该应用程序的某个方法存在内存泄漏后,对该方法生成的内存数据直接保存到磁盘,而不是申请内存空间进行保存。由于终端的磁盘空间较大,把这些内存数据保存到磁盘可以有效降低对内存空间的占用,从而避免内存泄漏时占用大量内存空间,影响整个系统的运行效率。
终端检测到该应用程序的某个方法存在内存泄漏后,系统提示用户,该应用程序存在异常,需要减少使用频率。
S107、终端替换方法包文件后,取消对该方法的降频处理并将方法生成的数据空间重新定位回内存区域。
终端收到服务器下发的应用程序中存在内存泄漏的方法对应的方法包文件(编译后的文件)后,使用服务器下发的方法包文件替换本地应用程序中对应的方法包文件(如obj文件)。替换该方法包文件后,应用程序动态加载该方法包文件;如果应用程序无法动态加载该方法包文件时,在替换该方法包文件后,应用程序需要进行重启。
终端在替换方法包文件后,判断该方法包文件不存在内存泄漏问题后,取消对该方法的降低使用频率的处理,同时把使用该方法生成的内存数据保存到内存空间,而不再保存到磁盘空间。
本实施例通过本专利提出的解决内存泄露的方法,通过降低发送内存协议的应用程序的方法的运行频率并将该方法生成的内存数据保存到磁盘的方式暂时解决泄露问题,解决后通过方法包文件的形式推送给终端,提高应用程序的运行流畅度,降低手机功耗。
实施例五
参考图5,一种解决内存泄露的方法,所述解决内存泄露的方法应用于服务器中,包括:
S201、服务器接收终端上传的每一个应用中所有方法生成的内存空间的大小,并进行统计分析。
服务器接收终端上传的每一个应用中所有方法生成的内存空间的大小信息,这些信息包括:应用程序名称、方法名称、方法生成的内存空间的大小。服务器收到这些信息后,把信息保存到数据库中,便于对应用程序进行分析。
服务器统计每个应用程序所有方法生成的内存空间的大小,获得一个应用程序所占内存的总和。同时对所有应用程序占用内存情况进行统计,获取占用内存最多的应用程序、占用内存最多的方法。
S202、服务器给所述每一个应用程序中所有方法的内存数据的大小设置一个阈值,然后把所述阈值推送给终端。
服务器根据每个应用程序的方法占用内存的大小,为每个方法占用内存数据设置一个阀值。占用内存较小的方法,对应的阀值较大;占用内存较大的方法,对应的阀值较小。如占用内存在1000字节的方法,设置的阀值为5;占用内存在1000字节-5000字节的方法,设置的阀值为3;占用内存在5000字节以上的方法,设置的阀值为2。
服务器把每个应用程序的方法占用内存的阀值信息推送给终端,推送的信息包括:用程序名称、方法名称、方法内存数据阀值。
S203、服务器接收终端上传的存在内存泄漏的方法信息,发送通知信息给相关人员,要求相关人员解决内存泄漏问题。
服务器接收到终端上传的存在内存泄漏的方法信息,这些信息包括:用程序名称、方法名称、方法调用链信息、内存占用大小。方法调用信息如:方法2->方法3->方法1。服务器接收到内存泄漏的上报信息后,根据应用程序名称、方法名称找到归属项目信息,然后给该项目的相关人员(如项目经理、应用程序开发人员)发送通知信息。通知信息包括:用程序名称、方法名称、方法调用链信息、内存占用大小。
项目相关人员根据服务器发送的信息,对存在内存泄漏的方法进行定位、风险,然后解决内存泄漏问题。
S204、服务器保存解决内存泄漏问题后的方法包文件,然后将所述解决内存泄漏问题后的方法包文件推送给终端。
项目相关人员解决内存泄漏问题后,对该应用程序的方法重新提交一份新的代码给服务器,然后服务器使用新的代码进行编译,得到编译后的方法包文件。项目相关人员把编译后的方法包文件上传到服务器,上传信息包括:应用程序名称、方法名称、方法包文件等信息。
服务器收到上传的方法包文件信息后,给所有包含该应用程序的终端推送修改后的方法包文件信息。服务器给终端推送方法包文件信息时,可以采用分批推送的方式,分时段给一部分终端推送信息。从而避免在短时间内给所有终端推送方法包文件信息,避免引起服务器处理资源占用过大问题。
本实施例通过服务器统计的各个应用方法生成的内存空间的大小及设定阈值,通知终端根据阀值监控可能存在的内存泄露方法。解决后通过方法包文件的形式推送给手机,不升级应用程序就能解决内存泄露的问题,提升用户体验。
实施例六
参考图6,一种解决内存泄露的服务器,包括:P206显示单元、P207用户输入单元、P210处理器、P209存储器及P208通信总线。
1)P206显示单元用于显示由用户输入的信息或提供给用户的信息;
2)P207用户输入单元用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入;
3)P208通信总线用于实现处理器和存储器之间的连接通信;
4)P209存储器用于存储程序数据;
5)P210处理器用于执行存储器中存储的解决内存泄露的程序,以实现以下步骤:
S201、服务器接收终端上传的每一个应用中所有方法生成的内存空间的大小,并进行统计分析。
服务器接收终端上传的每一个应用中所有方法生成的内存空间的大小信息,这些信息包括:应用程序名称、方法名称、方法生成的内存空间的大小。服务器收到这些信息后,把信息保存到数据库中,便于对应用程序进行分析。
服务器统计每个应用程序所有方法生成的内存空间的大小,获得一个应用程序所占内存的总和。同时对所有应用程序占用内存情况进行统计,获取占用内存最多的应用程序、占用内存最多的方法。
S202、服务器给所述每一个应用程序中所有方法的内存数据的大小设置一个阈值,然后把所述阈值推送给终端。
服务器根据每个应用程序的方法占用内存的大小,为每个方法占用内存数据设置一个阀值。占用内存较小的方法,对应的阀值较大;占用内存较大的方法,对应的阀值较小。如占用内存在1000字节的方法,设置的阀值为5;占用内存在1000字节-5000字节的方法,设置的阀值为3;占用内存在5000字节以上的方法,设置的阀值为2。
服务器把每个应用程序的方法占用内存的阀值信息推送给终端,推送的信息包括:用程序名称、方法名称、方法内存数据阀值。
S203、服务器接收终端上传的存在内存泄漏的方法信息,发送通知信息给相关人员,要求相关人员解决内存泄漏问题。
服务器接收到终端上传的存在内存泄漏的方法信息,这些信息包括:用程序名称、方法名称、方法调用链信息、内存占用大小。方法调用信息如:方法2->方法3->方法1。服务器接收到内存泄漏的上报信息后,根据应用程序名称、方法名称找到归属项目信息,然后给该项目的相关人员(如项目经理、应用程序开发人员)发送通知信息。通知信息包括:用程序名称、方法名称、方法调用链信息、内存占用大小。
项目相关人员根据服务器发送的信息,对存在内存泄漏的方法进行定位、风险,然后解决内存泄漏问题。
S204、服务器保存解决内存泄漏问题后的方法包文件,然后将所述解决内存泄漏问题后的方法包文件推送给终端。
项目相关人员解决内存泄漏问题后,对该应用程序的方法重新提交一份新的代码给服务器,然后服务器使用新的代码进行编译,得到编译后的方法包文件。项目相关人员把编译后的方法包文件上传到服务器,上传信息包括:应用程序名称、方法名称、方法包文件等信息。
服务器收到上传的方法包文件信息后,给所有包含该应用程序的终端推送修改后的方法包文件信息。服务器给终端推送方法包文件信息时,可以采用分批推送的方式,分时段给一部分终端推送信息。从而避免在短时间内给所有终端推送方法包文件信息,避免引起服务器处理资源占用过大问题。
本实施例通过服务器统计的各个应用方法生成的内存空间的大小及设定阈值,通知终端根据阀值监控可能存在的内存泄露方法。解决后通过方法包文件的形式推送给手机,不升级应用程序就能解决内存泄露的问题,提升用户体验。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个......”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
上面结合附图对本发明的实施例进行了描述,但是本发明并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本发明的启示下,在不脱离本发明宗旨和权利要求所保护的范围情况下,还可做出很多形式,这些均属于本发明的保护之内。

Claims (10)

1.一种解决内存泄露的方法,应用于终端,其特征在于,包括:
记录每一个应用程序的方法生成的内存空间的大小并上传至服务器;
对所述内存空间进行监控,监控所述内存空间是否发生内存泄露;
当所述内存空间发生内存泄露时,对导致内存泄露的所述应用程序的方法进行分析;
将所述方法的分析结果上报给所述服务器;
接收所述服务器推送的修改后的方法包文件,并使用所述方法包文件替换所述导致内存泄露的应用程序的方法对应的方法包文件。
2.根据权利要求1所述的解决内存泄露的方法,其特征在于,接收所述服务器推送的所述每一个应用程序的方法生成的内存空间大小的阈值;当监控到所述应用程序的方法生成的内存空间大小超过所述阈值时,认为所述应用程序的方法发生内存泄漏。
3.根据权利要求1所述的解决内存泄露的方法,其特征在于,当发生内存泄露后,降低所述导致内存泄露的应用程序的方法的运行频率并将所述方法生成的数据写入磁盘。
4.根据权利要求3所述的解决内存泄露的方法,其特征在于,替换所述应用程序的方法包文件后,取消对所述方法的降频处理并将所述应用程序的方法生成的数据写入内存。
5.一种解决内存泄露的方法,应用于服务器,其特征在于,所述方法包括:
接收终端上传的每一个应用程序的所有方法生成的内存空间大小,并进行统计分析;
接收所述终端上传的存在内存泄漏的方法信息,发送解决内存泄漏问题的通知信息给相关人员;
保存解决内存泄漏问题的方法包文件,然后将所述解决内存泄漏问题的方法包文件推送给所述终端。
6.根据权利要求5所述的解决内存泄露的方法,其特征在于,给所述每一个应用程序的所有方法生成的内存空间大小设置一个阈值,然后把所述阈值推送给所述终端。
7.根据权利要求5所述的解决内存泄露的方法,其特征在于,所述服务器自动获取最新提交的代码,对所述最新提交的代码及所述存在内存泄漏的方法生成一个方法包文件。
8.一种终端,其特征在于,包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的至少一个计算机程序,所述至少一个计算机程序被所述处理器执行时实现如权利要求1至4中任一项所述的解决内存泄露的方法中的步骤。
9.一种服务器,其特征在于,包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的至少一个计算机程序,所述至少一个计算机程序被所述处理器执行时实现如权利要求5至7中任一项所述的解决内存泄露的方法中的步骤。
10.一种计算机存储介质,所述计算机存储介质存储有计算机可执行的至少一个程序,其特征在于,所述至少一个程序被所述计算机执行时使所述计算机执行上述权利要求1至7任一项所述的方法中的步骤。
CN201810092448.9A 2018-01-30 2018-01-30 解决内存泄露的方法、终端、服务器及计算机存储介质 Active CN108377292B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201810092448.9A CN108377292B (zh) 2018-01-30 2018-01-30 解决内存泄露的方法、终端、服务器及计算机存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810092448.9A CN108377292B (zh) 2018-01-30 2018-01-30 解决内存泄露的方法、终端、服务器及计算机存储介质

Publications (2)

Publication Number Publication Date
CN108377292A true CN108377292A (zh) 2018-08-07
CN108377292B CN108377292B (zh) 2020-11-10

Family

ID=63017081

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810092448.9A Active CN108377292B (zh) 2018-01-30 2018-01-30 解决内存泄露的方法、终端、服务器及计算机存储介质

Country Status (1)

Country Link
CN (1) CN108377292B (zh)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110457179A (zh) * 2019-07-29 2019-11-15 Oppo广东移动通信有限公司 系统检测方法、内存监控方法、装置、介质与电子设备
CN113342565A (zh) * 2021-06-25 2021-09-03 珠海菲森电力科技有限公司 一种防止内存泄漏的方法及系统
CN113688052A (zh) * 2021-08-31 2021-11-23 南方电网科学研究院有限责任公司 一种电表应用程序内存泄露监测方法、终端、设备和介质

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1567248A (zh) * 2003-07-01 2005-01-19 华为技术有限公司 应用程序日志记录方法及系统
CN104199732A (zh) * 2014-08-28 2014-12-10 上海新炬网络技术有限公司 一种pga内存溢出智能处理方法
CN105204996A (zh) * 2015-09-24 2015-12-30 努比亚技术有限公司 内存泄露检测装置及方法、终端
CN105373479A (zh) * 2015-12-14 2016-03-02 厦门美图移动科技有限公司 一种内存泄露的自动化测试方法、装置及移动终端
CN105740122A (zh) * 2016-01-26 2016-07-06 广东欧珀移动通信有限公司 一种手机内存泄漏的监测方法及监测系统
US9525593B2 (en) * 2012-06-29 2016-12-20 Broadcom Corporation Oversubscribing a packet processing device to adjust power consumption
CN106844159A (zh) * 2017-02-03 2017-06-13 广东欧珀移动通信有限公司 一种信息获取方法、装置及智能终端
CN107357656A (zh) * 2017-06-27 2017-11-17 努比亚技术有限公司 一种内存分配方法、移动终端以及计算机可读存储介质

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN1567248A (zh) * 2003-07-01 2005-01-19 华为技术有限公司 应用程序日志记录方法及系统
US9525593B2 (en) * 2012-06-29 2016-12-20 Broadcom Corporation Oversubscribing a packet processing device to adjust power consumption
CN104199732A (zh) * 2014-08-28 2014-12-10 上海新炬网络技术有限公司 一种pga内存溢出智能处理方法
CN105204996A (zh) * 2015-09-24 2015-12-30 努比亚技术有限公司 内存泄露检测装置及方法、终端
CN105373479A (zh) * 2015-12-14 2016-03-02 厦门美图移动科技有限公司 一种内存泄露的自动化测试方法、装置及移动终端
CN105740122A (zh) * 2016-01-26 2016-07-06 广东欧珀移动通信有限公司 一种手机内存泄漏的监测方法及监测系统
CN106844159A (zh) * 2017-02-03 2017-06-13 广东欧珀移动通信有限公司 一种信息获取方法、装置及智能终端
CN107357656A (zh) * 2017-06-27 2017-11-17 努比亚技术有限公司 一种内存分配方法、移动终端以及计算机可读存储介质

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110457179A (zh) * 2019-07-29 2019-11-15 Oppo广东移动通信有限公司 系统检测方法、内存监控方法、装置、介质与电子设备
CN113342565A (zh) * 2021-06-25 2021-09-03 珠海菲森电力科技有限公司 一种防止内存泄漏的方法及系统
CN113688052A (zh) * 2021-08-31 2021-11-23 南方电网科学研究院有限责任公司 一种电表应用程序内存泄露监测方法、终端、设备和介质

Also Published As

Publication number Publication date
CN108377292B (zh) 2020-11-10

Similar Documents

Publication Publication Date Title
CN108536481A (zh) 一种应用程序启动方法、移动终端及计算机存储介质
CN108551411A (zh) 数据采集方法、移动终端及计算机可读存储介质
CN107688607A (zh) 一种数据库访问的方法及移动终端、计算机可读存储介质
CN108664329A (zh) 一种资源配置方法、终端及计算机可读存储介质
CN108595203A (zh) 应用功能执行方法、移动终端和计算机可读存储介质
CN107247606A (zh) 应用程序管理方法、装置及计算机可读存储介质
CN108377292A (zh) 解决内存泄露的方法、终端、服务器及计算机存储介质
CN109766119A (zh) 恢复分区升级方法、终端和计算机可读存储介质
CN108536768A (zh) 图片加载方法、终端及计算机可读存储介质
CN108762926A (zh) 一种系统优化方法、终端及计算机可读存储介质
CN108536383A (zh) 一种游戏控制方法、设备及计算机可读存储介质
CN109545120A (zh) 屏幕光感传感器调节方法、移动终端和计算机可读存储介质
CN108366303A (zh) 一种视频播放方法、移动终端及计算机可读存储介质
CN108566456A (zh) 拍摄方法、移动终端和计算机可读存储介质
CN107911778A (zh) 一种基于并联喇叭的播放方法、移动终端及可读存储介质
CN107704287A (zh) 程序应用免安装方法、移动终端及计算机可读存储介质
CN107360376A (zh) 一种拍摄方法及终端
CN107133108A (zh) 分布式复杂锁的实现方法、终端、服务器及计算机可读存储介质
CN109947519A (zh) 硬件加速控制方法、终端和计算机可读存储介质
CN110141851A (zh) 一种录屏方法、装置及计算机可读存储介质
CN108768831A (zh) 聊天记录的分享方法、移动终端及计算机可读存储介质
CN108771870A (zh) 基于游戏的语音传输方法、终端及计算机可读存储介质
CN108879117A (zh) 移动终端及其天线结构
CN108667714A (zh) 信息的发送方法、接收方法、移动终端及存储介质
CN107766211A (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