首页 文章 精选 留言 我的

精选列表

搜索[优化],共10000篇文章
优秀的个人博客,低调大师

Android优化—— 内存分析工具 MAT 的使用

1内存泄漏的排查方法 Dalvik Debug Monitor Server (DDMS)是ADT插件的一部分,其中有两项功能可用于内存检查: ·heap查看堆的分配情况 ·allocation tracker跟踪内存分配情况 DDMS这两项功能有助于找到内存泄漏的操作行为。 Eclipse Memory Analysis Tools (MAT)是一个分析Java堆数据的专业工具,用它可以定位内存泄漏的原因。 工具地址:https://www.eclipse.org/mat/ 1.1观察Heap ·运行程序,然后进入DDMS管理界面,如下: PS :点击工具栏上的来更新统计信息 点击右侧的Cause GC按钮或工具栏上的即可查看当前的堆情况,如下: 主要关注两项数据: oHeap Size堆的大小,当资源增加,当前堆的空余空间不够时,系统会增加堆的大小,若超过上限(例如64M,视平台和具体机型而定)则会被杀掉 oAllocated堆中已分配的大小,这是应用程序实际占用的内存大小,资源回收后,此项数据会变小 ·查看操作前后的堆数据,看是否有内存泄漏对单一操作(比如添加页,删除页)进行反复操作,如果堆的大小一直增加,则有内存泄漏的隐患。 获取 hprof文件点击工具栏上的按钮,将内存信息保存成文件。如果是用MAT Eclipse插件获取的Dump文件,则不需要经过转换,Adt会自动进行转换然后打开。 ·转换hprof文件 DDMS Dump出的文件要经过转换才能被MAT识别,Android SDK提供了这个工具hprof-conv(位于sdk/tools下) ·./hprof-conv xxx-a.hprof xxx-b.hprof ·用MAT打开转换后的hprof文件 1.3 Histogram 查询 用的最多的功能是Histogram,点击Actions下的Histogram项将得到Histogram结果: 它按类名将所有的实例对象列出来,可以点击表头进行排序,在表的第一行可以输入正则表达式来匹配结果: 在某一项上右键打开菜单选择list objects ->with incoming refs将列出该类的实例: 它展示了对象间的引用关系,比如展开后的第一个子项表示这个HomePage(0x420ca5b0)被HomePageContainer(0x420c9e40)中的mHomePage属性所引用. 快速找出某个实例没被释放的原因,可以右健Path to GC Roots-->exclue all phantom/weak/soft etc. reference: 得到的结果是: 从表中可以看出PreferenceManager -> … ->HomePage这条线路就引用着这个HomePage实例。用这个方法可以快速找到某个对象的GC Root,一个存在GC Root的对象是不会被GC回收掉的. 1.4 Histogram 对比 为查找内存泄漏,通常需要两个Dump结果作对比,打开Navigator History面板,将两个表的Histogram结果都添加到Compare Basket中去: 添加好后,打开Compare Basket面板,得到结果: 点击右上角的!按钮,将得到比对结果: 注意,上面这个对比结果不利于查找差异,可以调整对比选项: 再把对比的结果排序,就可得到直观的对比结果: 也可以对比两个对象集合,方法与此类似,都是将两个Dump结果中的对象集合添加到Compare Basket中去对比。找出差异后用Histogram查询的方法找出GC Root,定位到具体的某个对象上。 1.5 例子 举例一个典型的分析内存泄漏的过程: 1.使用Heap查看当前堆大小为23.00M 2.添加一个页后堆大小变为23.40M 3.将添加的一个页删除,堆大小为23.40M 4.多次操作,结果仍相似,说明添加/删除页存在内存泄漏(也应注意排除其它因素的影响) 5.Dump出操作前后的hprof文件(1.hprof,2.hprof),用mat打开,并得到histgram结果 6.使用HomePage字段过滤histgram结果,并列出该类的对象实例列表,看到两个表中的对象集合大小不同,操作后比操作前多出一个HomePage,说明确实存在泄漏 7.将两个列表进行对比,找出多出的一个对象,用查找GC Root的方法找出是谁串起了这条引用线路,定位结束 PS : ·很多时候堆增大是Bitmap引起的,Bitmap在Histogram中的类型是byte [],对比两个Histogram中的byte[]对象就可以找出哪些Bitmap有差异 ·多使用排序功能,对找出差异很有用 存在无效的引用 !良好的模块设计以及合理使用设计模式有助于解决此问题。 使用 android:largeHeap="true"标记(API Level >= 11)在AndroidManifest.xml中的Application节点中声明即可分配到更大的堆内存, android:largeHeap标记在Android系统应用中也有广泛的应用,比如Launcher, Browser这些内存大户上均有使用. DDMS 官方教程http://developer.android.com/tools/debugging/ddms.html ·MAT下载http://www.eclipse.org/mat/downloads.php ·MAT使用http://android-developers.blogspot.tw/2011/03/memory-analysis-for-android.html 同事起草,整理分享,可以转载收录。 本文转自 一点点征服 博客园博客,原文链接:http://www.cnblogs.com/ldq2016/p/5239234.html,如需转载请自行联系原作者

优秀的个人博客,低调大师

日志系统之HBase日志存储设计优化

本人博客文章如未特别注明皆为原创!如有转载请注明出处:http://blog.csdn.net/yanghua_kobe/article/details/46482319 继续谈论最近接手的日志系统,上篇关于日志收集相关的内容,这篇我们谈谈日志存储相关的话题。 简介 我们首先来总结一下日志这种数据的业务特点:它几乎没有更新的需求,一个组件或一个系统通常有一个固定的日志格式,但就多个组件或系统而言它会存在各种五花八门的自定义的tag,这些tag建立的目的通常是为了后期查询/排查线上问题的需要,因此日志的检索字段也灵活多变。 我们的日志存储选择是HBase,这主要是因为我们认为HBase的如下特点非常适合日志数据: (1)HBase的qualifier相当灵活,可以动态创建,非常适合日志这种tag不固定的半结构化数据(这里的灵活性主要针对tag

资源下载

更多资源
Mario

Mario

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Nacos

Nacos

Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service 的首字母简称,一个易于构建 AI Agent 应用的动态服务发现、配置管理和AI智能体管理平台。Nacos 致力于帮助您发现、配置和管理微服务及AI智能体应用。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据、流量管理。Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。

Spring

Spring

Spring框架(Spring Framework)是由Rod Johnson于2002年提出的开源Java企业级应用框架,旨在通过使用JavaBean替代传统EJB实现方式降低企业级编程开发的复杂性。该框架基于简单性、可测试性和松耦合性设计理念,提供核心容器、应用上下文、数据访问集成等模块,支持整合Hibernate、Struts等第三方框架,其适用范围不仅限于服务器端开发,绝大多数Java应用均可从中受益。

Rocky Linux

Rocky Linux

Rocky Linux(中文名:洛基)是由Gregory Kurtzer于2020年12月发起的企业级Linux发行版,作为CentOS稳定版停止维护后与RHEL(Red Hat Enterprise Linux)完全兼容的开源替代方案,由社区拥有并管理,支持x86_64、aarch64等架构。其通过重新编译RHEL源代码提供长期稳定性,采用模块化包装和SELinux安全架构,默认包含GNOME桌面环境及XFS文件系统,支持十年生命周期更新。

用户登录
用户注册