首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Android内存性能测试

前言 Android应用大部分性能问题归根结底都会成为内存的问题,今天我们就先以Out of Memory(OOM)为起点介绍一下Android内存的原理以及排查内存问题的方法。...原理 在讲OOM之前我们先来弄清楚几个概念:内存泄漏、内存抖动、内存溢出 内存泄漏:内存泄漏是指没有用的对象资源仍与GC-Root保持可达路径,导致系统无法进行回收; 内存抖动:内存抖动是因为大量的对象被创建又在短时间内马上被释放...除了减少内存的申请回收外,更重要的是减少常驻内存和避免内存泄漏,说起内存泄漏,就必须要提Activity内存泄漏。...现在我们来归纳一下,内存问题主要包括常驻问题(主要是图片缓存)、泄漏问题(主要是Activity泄漏)、GC问题(关键是GC For Alloc),后果会导致App Crash、闪退、后台被杀、卡顿,而且这是各种资源类性能问题积压的最后一环...,因为在日常测试和开发过程中,即便客户端接了内存泄漏检测的工具,但也只是作为一个debug工具,很难系统的看出某个版本的应用内存泄漏情况是如何的。

1.5K10

Android 性能测试内存性能内存泄漏篇

性能测试-内存性能内存泄漏篇 数据源 APP占用内存测试,要比CPU的更为简单。App memory数据来源是dumpsysmeminfo。...只要数据曲线不是如下图中的灰色平缓曲线,则可以证明该场景是有内存泄漏的。 图三 内存泄漏示意图 同样,如果只提供上述的曲线给开发,定位问题也会比较麻烦,测试内存泄漏的测试中,也可以多做一些。...图四DDMSdump内存 拿到hprof文件后,可以导入Android Studio中查看,一般查看Retained Size占用最大的类,分析是否有内存泄漏,一个对象的 Shallow Heap, 指的是该对象自身占用内存的大小...图五 使用Android Studio查看内存泄漏 Android Studio的分析不够强大,也可以借助MAT来分析内存泄漏:更多内容。...笔者目前水平止步于此,后续将继续深入学习内存泄漏测试的相关内容。 文章来源于:腾讯移动品质中心 TMQ

2.5K00
您找到你想要的搜索结果了吗?
是的
没有找到

【 Android 场景化性能测试内存性能内存泄漏篇

作者:陈帅团队:腾讯移动品质中心TMQ 一、数据源 APP占用内存测试,要比CPU的更为简单。App memory数据来源是dumpsys meminfo。...Android程序内存主要是两部分:native和dalvik。...[1509070479432_1215_1509070714109.png] 图三内存泄漏示意图 同样,如果只提供上述的曲线给开发,定位问题也会比较麻烦,测试内存泄漏的测试中,也可以多做一些。...占用最大的类,分析是否有内存泄漏,一个对象的ShallowHeap,指的是该对象自身占用内存的大小。...篇幅有限,还有很多深入的内容无法一一铺陈,后续将继续深入学习内存泄漏测试的相关内容。 搜索微信公众号:腾讯移动品质中心TMQ,获取更多测试干货!

1.7K10

Web 性能测试-内存泄漏测试方法之chrome内存快照

首先明确一下我们测试的目的:客户端浏览器的js内存是否存在泄漏,服务器端的话可不是这么测,防止用户使用时浏览器卡顿或崩溃。 F12打开开发者工具,选中Memory页签下的Heap snapshot。...测内存泄漏就是看我们做了一些操作前后内存的变化,比如我们在重复做查询操作,每次操作后的快照都会增加几兆或更多,这就说明可能是存在内存泄漏。...注: 你做不同的事,内存增长不一定是内存泄漏哦,他可能是正常的加载一些必要的东西占用的内存而已。总之就是做这一种事只需要固定的那么多内存,要是每次都新增加了一些内存,说明加载的东西重复了。...可能是之前不用的内存没释放,或是新加载了一些没用的内存。...快速测试内存泄漏 每次我们都要做快照的话如果内存大的话快照是比较慢的,快照主要是开发来对比找问题用的,我们测试只需要发现问题就好了。

5.5K20

内存分配器性能测试

但是既然go语言已经支持垃圾回收,还有必要自己去写一个内存分配器吗?我们做一个简单的测试看看结果怎么样。...测试平台: OS: ubuntu 12.04 x86_64 CPU: i5 2.27G MEMORY: 8G // ben1.go 自己实现内存分配器 package main type Pool struct...package main func main() { for i := 0; i < 10000000; i++ { _ = make([]byte, 100) } } 编译测试: go build.../ben2 测试结果: 次数 ben1(s) ben2(s) 1 0.308 2.057 2 0.304 2.048 3 0.308 2.093 平均 0.307 2.066 结论: 可以看到,自己实现的内存分配器的执行时间大约是系统内存分配器的十分之一...因此对于一些特定应用场景,比如网络库等,使用自定义内存分配器还是很有必要的。由于go语言提供了垃圾收集功能,所以实现自定义内存分配器相比较在C/C++里简单很多。

1.2K60

Java直接内存与非直接内存性能测试

对于直接内存来说,JVM将会在IO操作上具有更高的性能,因为它直接作用于本地系统的IO操作。而非直接内存,也就是堆内存中的数据,如果要作IO操作,会先复制到直接内存,再利用本地IO处理。...文档中也说了,直接内存使用allocateDirect创建,但是它比申请普通的堆内存需要耗费更高的性能。不过,这部分的数据是在JVM之外的,因此它不会占用应用的内存。...所以呢,当你有很大的数据要缓存,并且它的生命周期又很长,那么就比较适合使用直接内存。只是一般来说,如果不是能带来很明显的性能提升,还是推荐直接使用堆内存。...可以总结下,直接内存的使用场景: 1 有很大的数据需要存储,它的生命周期又很长 2 适合频繁的IO操作,比如网络并发场景 申请分配地址速度比较 下面用一段简单的代码,测试下申请内存空间的速度: int...在数据量提升时,直接内存相比于非直接内存的申请 有十分十分十分明显的性能问题!

1.4K50

memtier_benchmark内存性能测试利器

// memtier_benchmark内存性能测试工具 // 最近在测试英特尔的傲腾可持久化内存,使用到了memtier_benchmark这个工具,在使用这个工具的时候,遇到了一些问题,我简单总结了一下...,写在这里,后续如果有测试需求,可以参考下。...memtier_benchmark是类似redis-benchmark的内存测试工具,但是它又不仅限redis的测试,还可以覆盖memcache,它提供了丰富的选项和报表功能,能够产生各种各样的流量模拟...memtier_benchmark安装方法还是有必要了解下的,因为我自己的安装的时候出现了一些小问题,这里给出一个经过测试的安装过程: 1、准备工作 ## 安装编译环境 yum install -y autoconf...-s --server:代表服务器地址,默认localhost -p --port:代表端口,默认为redis的6379端口 -x --run-number:代表完整测试的重复次数 --client-stats

4.1K20

APP性能测试内存使用率

Android 内存测试 获取设备内存信息 在Linux操作系统中,/proc是一个位于内存中的伪文件系统(in-memory pseudo-file system)。...Dex文件有索引区和Data区 Other mmap 其它文件占用的内存 自动化获取性能数据 前面我们使用adb命令获取CPU,内存性能数据,但是如果想批量获取性能数据,使用命令一个个查询会非常的不方便...self.counter - 1 time.sleep(3) def SaveDataToCSV(self,data_type): ''' 存储性能测试数据...内存泄漏会因为减少可用内存的数量从而降低设备的性能。 Android 内存泄漏测试可以在APP中集成LeakCanary进行测试。...内存测试 Instruments内存分析 打开Instruments 然后选择 Leaks进入主界面,选择测试设备和测试应用点击开始执行,底部菜单选择CallTree(如下图),并在底部勾选hide System

3.9K31

腾讯TMQ在线沙龙|android内存性能测试

Android内存性能测试 活动时间:2016年10月31日 QQ群视频交流 活动介绍:TMQ在线沙龙第十一期分享 本次分享的主题是老司机给大家分享android内存性能测试。...共有104位测试小伙伴报名参加活动,在线观看视频人数52人~想知道活动分享了啥吗?往下看吧! 活动嘉宾 ? 嘉宾简介 张志伟,腾讯高级测试工程师,目前负责手机管家的性能测试及优化。...有多年的前后台性能测试经验。...6、提问:请问我们想将内存性能测试应用于monkey自动化测试中,执行monkey压测时候,能收集到手机内存变化数据,让我们在monkey运行完成之后画出相应的内存变化曲线。...15、提问:android 内存性能分析,一般在项目的什么阶段开展比较合适 答: 性能测试分析的时间成本可能较高,一般是在集成阶段。如果能够自动化采集性能数据,可以提前一些。

1.6K60

.Net Core内存回收模式及性能测试对比

这种模式的特点是初始分配的内存较大,并且尽可能不回收内存,进行回收用时会很耗时,并进行内存碎片整理工作。用一句简单的话说,这个就是贪婪模式,通过尽可能多的获得内存和少回收来得到更好的性能。...结果就是高内存使用率性能较好。 Workstation GC : 主要应用于单处理器系统,Workstation GC尽可能地通过减少垃圾回收过程中程序的暂停次数来提高性能。...结果就是低内存使用率性能较差。...,情况如下图所示: image.png 经过反复多次的测试内存最高时涨到800多M,这与可用内存有关系,如果可用内存更多,还会涨到1G或更高然后再掉下来: image.png Workstation...Net Core默认的贪婪模式可以得到更好的性能,这没有什么问题是,毕竟内存不用放在那也是浪费。当然如果你的服务器上许多的程序在跑,并对内存有较高的限制要求不要影响到其它的程序,那就要做一些配置了。

1.5K110

转--Golang语言 内存分配器性能测试

但是既然go语言已经支持垃圾回收,还有必要自己去写一个内存分配器吗?我们做一个简单的测试看看结果怎么样。...测试平台: OS: ubuntu 12.04 x86_64 CPU: i5 2.27G MEMORY: 8G // ben1.go 自己实现内存分配器 package main type Pool struct...package main func main() { for i := 0; i < 10000000; i++ { _ = make([]byte, 100) } } 编译测试: go build.../ben2 测试结果: 次数 ben1(s) ben2(s) 1 0.308 2.057 2 0.304 2.048 3 0.308 2.093 平均 0.307 2.066 结论: 可以看到,自己实现的内存分配器的执行时间大约是系统内存分配器的十分之一...因此对于一些特定应用场景,比如网络库等,使用自定义内存分配器还是很有必要的。由于go语言提供了垃圾收集功能,所以实现自定义内存分配器相比较在C/C++里简单很多。

1K40

性能测试-性能测试指标

20230114_性能测试-性能测试指标 本文总结接口性能测试中,常见的性能指标概念,查看及通用通过标准 注: 本文只考虑B/S架构 4.性能测试指标.pdf Jmeter.xlsx 客户端指标 并发用户数...超过此节点理发师开始自乱阵脚 设定及查看方式 设定测试计划时, 选择合适的并发用户数对系统进行测试 通过性能测试, 通过找到产品的最佳并发数和最大并发数 准过标准 最佳并发数应该大于系统平均负载, 否则需要进行优化...Error% 概念 所有请求中失败请求的占比 查看方式 Jmeter中通过Aggregate Report查看 准过标准 一般业务: 失败率<0.5% 重要业务: 失败率=0 点击率Hit Rate 概念 性能测试指...< 70% 且Swap基本无使用 内存利用率 SWAP使用率 评级 <70% <30% 好 70%-90% 30%-60% 一般 >90% > 60% 差 性能分析 操作系统为了最大化利用内存,一般都设置大量的...使用top及ps命令确认占用大量内存的线程, 并通知开发 磁盘IO 概念 磁盘IO指的是服务器对磁盘进行数据的读取和写入 由于读写磁盘的消耗较大, 过高的磁盘IO会影响系统整体性能 一般使用iostat

12710

性能测试篇:入门性能测试

性能测试一直是测试行业中比较难的一块,含金量比较高,工作经验越多工资越高,而且最近很多招聘中初级测试都要求会性能测试,要求越来越高了,那我们就一起学习性能测试吧!...负载测试:在一定软件硬件的环境下,不断进行增加负载,来确定满足性能指标情况下能够承受的最大用户数 性能测试:模拟用户在负载环境下,测试系统的响应时间和吞吐量是否满足性能指标的要求 TPS:每秒完成的事务数...RT:响应时间 pv:每秒用户访问页面的次数 三、使用jmeter完成接口测试 要学习性能测试,就不得不先去学习如何使用jmeter测试,下面给大家介绍个简单的案例,后面我会不断更新性能测试合集,这里只是入门

4.6K10

性能测试-Jmeter性能测试实战

ie=utf-8&wd=jmeter性能测试 请求参数: >ie:编码方式,默认为utf-8 >wd: 搜索词 返回结果:搜索结果,通过校验结果中是否含有搜索词wd来判断本次请求成功或失败 二、实际操作...当启动时间已过,手动只需测试时当前时间也会覆盖它。 结束时间:测试结束时间,持续时间会覆盖它。 因为接口调试需要,我们暂时均使用默认设置,待后面真正执行性能测试时再回来配置。...这样,我们就完成了一个完整Http接口的JMeter性能测试脚本编写。...8、重新配置线程组,做性能测试。...点击线程组,配置本次性能测试相关参数:线程数,循环次数,持续时间等,这里我们配置并发用户数为10,持续时间为50s 9、重新执行绿色小箭头并查看报告 聚合报告参数讲解: a.

6.6K31

测者的性能测试手册: 内存异常-JVM内存故障排查方法

今天测者和你一起学习JVM内存的故障排查方法。...用来跟踪Java 内存的使用情况,NMT可以追踪到堆内内存、code区域、通过unsafe.allocateMemory和DirectByteBuffer申请的内存,NMT不能跟踪C代码的申请的堆外内存的情况...参数说明如下: 参数 说明 off 默认是off,关闭NMT summary 只收集汇总信息 detail 收集全部信息 特别提醒:开启NMT后,性能会有5%-10%的损耗,因此,在发现有内存问题后,...、打印虚拟内存映射、打印由呼叫站点聚合的内存使用情况 baseline 创建内存快照,以比较不同时间的内存差异 summary.diff 打印自上次baseline到现在的内存差异,显示汇总信息 detail.diff...,因此可以怀疑存在内存泄露问题。

87120

Nginx缓存区内存配置大小对性能测试的影响

现象:Nginx与应用都在同一台服务器(4g内存、4核cpu)上,nginx缓存区内存配置1g,开启nginx的accesslog,跑图片终端页性能脚本,观察到accesslog里面有90%以上的MISS...状态的,nginx缓存没有起到作用,加大nginx缓存内存为2g,清了缓存再次跑性能脚本,accesslog中的MISS状态仍占大部分,且应用服务器的内存空间基本被用完。...解决:将nginx与应用分开,nginx放在一台服务器上,应用包搬到另一服务器(6g内存、8核cpu)上,跑图片终端页脚本,nginx缓存区内存配置2g,观察到响应提上去了,accesslog里HIT状态的占...当调整到2G时,由于服务器上还存放应用也占了内存,另外系统也需要资源,导致nginx所配置的2G内存没起作用。当把nginx和应用分开时,资源都充足了,这时nginx的缓存区也能起到作用。

1.2K20

win32应用程序性能测试-内存

本文主要讲述windows平台下应用程序性能测试内存相关的知识,通过本文了解内存基本原理和分析内存占用问题。 一、内存是什么?...windows就会消减工作集,会导致整体性能变差。...HardPageFault需要去系统的pagefile.sys里查找,这个查找过程会产生大量的IO操作,影响性能。 ?...2缺点 刷内存只是将可能暂时不需要工作集swap出去,如果业务又再需要,需从虚拟内存的pagefile里调用过来,这个过程反而降低系统性能,所以不推荐使用 2减少页错误 这里推荐的操作是预处理,减少随机...四、结尾 性能里调优内存涉及的点比较多,上面几个例子只是部分。建议平时先建设基础基准数据,有业务增加及时定位。 附我们内存优化的一些方向: ?

1.4K81

Android性能测试——发现和定位内存泄露和卡顿

因此,对开发的Android应用,必须对其进行性能测试,不然将会直接影响用户体验。   Android应用性能测试通常包括:启动时间、内存、CPU、耗电量、流量、流畅度等。...我们将在这个月陆续为大家简单介绍一下每个测试点的常见测试方法及简单的定位思路,仅供参考。...之前两周内,我们为大家介绍了启动时间、内存&CPU测试方法,本期我们介绍Android测试的难题——内存泄漏和卡顿。 内存泄露   内存泄露方面使用MAT工具定位分析。   ...,测试结束后,点击Cause GC   4)点击Dump HPROF file,将该应用当前的内存信息保存成hprof文件 ?   ...图9   上述四种方法就是测试FPS流畅度的常用方法。当QA发现有卡顿问题时,可以从以下几点着手分析,逐一排查。

2.3K20

性能测试必备知识(10)- Linux 是怎么管理内存的?

性能测试的必备知识系列,可以看下面链接的文章哦 https://www.cnblogs.com/poloyy/category/1806772.html 内存映射 日常生活常说的内存是什么 比方说,我的笔记本电脑内存就是...8GB 的 这个内存其实是物理内存 物理内存也称为主存,大多数计算机用的主存都是动态随机访问内存(DRAM) 灵魂拷问 只有内核才可以直接访问物理内存,那么进程要访问内存时,怎么办?...为什么会有内存映射 既然每个进程都有一个这么大的地址空间,那么所有进程的虚拟内存加起来,自然要比实际的物理内存大得多 所以,并不是所有的虚拟内存都会分配物理内存,只有那些实际使用的虚拟内存才分配物理内存...并且分配后的物理内存,是通过内存映射来管理的 什么是内存映射 内存映射,其实就是将虚拟内存地址映射到物理内存地址 为了完成内存映射,内核为每个进程都维护了一张页表,记录虚拟地址与物理地址的映射关系 ?...Swap 会导致严重的内存性能问题 OOM 是内核的一种保护机制 它监控进程的内存使用情况,并且使用 oom_score 为每个进程的内存使用情况进行评分: 一个进程消耗的内存越大,oom_score

1.9K30
领券