iOS Instruments内存检测使用

Instruments 可以帮我们了解到应用程序使用内存的几个方面:

  • 全局内存使用情况(Overall Memory Use): 从全局的角度监测应用程序的内存使用情况,捕捉非预期的或大幅度的内存增长。
  • 内存泄露(Leaked memory): 未被你的程序引用,同时也不能被使用或释放的内存。
  • 废弃内存(Abandoned memory): 被你的程序引用,但是没什么卵用的内存。
  • 僵尸对象(Zombies): 僵尸对象指的是对应的内存已经被释放并且不再会使用到,但是你的程序却在某处依然有指向它的引用。在 iOS 中有一个 NSZombie 机制,这个是为了内存调试的目的而设计的一种机制。在这个机制下,当你 NSZombieEnabled 为 YES 时,当一个对应的引用计数减为 0 时,这个对象不会被释放,当这个对象再收到任何消息时,它会记录一条 warning,而不是直接崩溃,以方便我们进行程序调试。

这里我们介绍下查找内存泄露的过程:

1、同「CPU 占用性能测试」一样,先在 Xcode 中对当前的项目执行 Profile (Command-I),并在打开的对话框中选择 Leaks 这个模板:

2、进入 Instruments 后,选择正确的设备和应用程序。

3、点击红色按钮运行应用程序,我们可以看到如下界面:

4、在 Display Settings 中勾选 Invert Call TreeHide System Libraries 或其他选项可以过滤显示的数据。

5、在导航栏的筛选框中,我们可以输入关键字来筛选数据。

6、在实际使用中,我们进入一个页面后再退出,发现相关的内存分配没有清空,这时候就发生内存泄露了。我们查看更细节的调用信息,追踪到可能造成内存泄露的代码位置:

7、我们还可以使用 Activity MonitorAllocationsZombies 等模板来针对性地做内存监测。



在开发中我一般是使用Xcode自带的instrument工具就够用了,它的快捷键是(commend+i),是自带的一个可以用来分析应用程序的性能,

有三个功能在开发中经常用到,

1、Leaks就可以检测内存泄漏,利用它可以看到全局的一个内存使用情况,也可以查看是否存在内存泄漏,是否存在野指针;

2、是可以使用 Core Animation + Time Profiler 来评估图形性能,可以很直观的看到界面的性能是否良好。

3、Time Profiler在应用程序开始运行后.我们可以看到不同的线程以及方法调用占用的时间,从而可以评估出 CPU 性能的瓶颈和找到优化方向。

但在使用Xcode这个工具的时候有2个注意点:

1.需要使用真机。因为手机的CPU,GPU和模拟器是有区别的,mac的Cpu是比手机快的,而模拟器要用CPU来模拟手机的GPU,这点模拟器是比不上手机的。

2.应用程序运行一定要发布配置 而不是调试配置.,因为打包的时候,编译器会自动进行优化,比如去除调试符号或者移除并重新组织代码,还会引入"Watch Dog"[看门狗]机制,不同的场景下,“看门狗”会监测应用的性能,但在xcode的配置设置下,watch Dog会被禁用。

时间: 2024-10-20 10:51:13

iOS Instruments内存检测使用的相关文章

ios Instruments 内存泄露

本文转载至 http://my.oschina.net/sunqichao/blog?disp=2&p=3 虽然iOS 5.0版本之后加入了ARC机制,由于相互引用关系比较复杂时,内存泄露还是可能存在.所以了解原理很重要. 这里讲述在没有ARC的情况下,如何使用Instruments来查找程序中的内存泄露,以及NSZombieEnabled设置的使用. 本文假设你已经比较熟悉Obj-C的内存管理机制. 实验的开发环境:XCode 4.5.2 1.运行Demo. 先下载一个实现准备好的内存泄露的D

理解 iOS 的内存管理

理解 iOS 的内存管理 远古时代的故事 那些经历过手工管理内存(MRC)时代的人们,一定对 iOS 开发中的内存管理记忆犹新.那个时候大约是 2010 年,国内 iOS 开发刚刚兴起,tinyfool 大叔的大名已经如雷贯耳,而我还是一个默默无闻的刚毕业的小子.那个时候的 iOS 开发过程是这样的: 我们先写好一段 iOS 的代码,然后屏住呼吸,开始运行它,不出所料,它崩溃了.在 MRC 时代,即使是最牛逼的 iOS 开发者,也不能保证一次性就写出完美的内存管理代码.于是,我们开始一步一步调试

iOS Instruments工具使用

iOS性能优化:Instruments工具 前言:即使再牛的程序员,写出再棒的代码依然存在很多可优化的地方,更别说我们普通程序员写出的普通的代码(例如笔者)更是有很多的优化以及bug需要我们去调试.所以代码优化是我们必须掌握的技能. 今天笔者给大家介绍一款代码分析优化工具:Xcode自带的检测调试工具Instruments. Instruments提供了很多功能,我会重点介绍一下我最常用的几类: 1.Time Profiler:CPU分析工具分析代码的执行时间. 2.Core Animation

iOS instruments之ui automation的简单使用(高手绕道)

最近使用了几次instruments中的automation工具,现记录下automation的简单使用方法,希望对没接触过自动化测试又有需求的人有所帮助.  UI 自动测试是iOS 中重要的附加功能,它由名为"Automation"的新的工具对象支持.Automation工具的脚本是用JavaScript语言编写,主要用于分析应用的性能和用户行为,模仿/击发被请求的事件,利用它可以完成对被测应用的简单的UI测试及相关功能测试. 一. 简单的录制脚本 打开xcode,这里用我为我家亲爱

iOS平台内存使用原则

2 iOS平台内存使用原则 2.1 对象的所有权与销毁 2.1.1 谁创建,谁释放: 如果是以alloc,new或者copy,mutableCopy创建的对象,则必须调用release或者autorelease方法释放内存: 如果没有释放,则导致内存泄漏! 2.1.2 谁retain,谁释放: 如果对一个对象发送 retain消息,其引用计数会+1,则使用完必须发送release或者autorelease方法释放内存或恢复引用计数: 如果没有释放,则导致内存泄漏! 2.1.3 没创建且没reta

说说iOS与内存管理(上)

http://www.cocoachina.com/ios/20150625/12234.html 说起内存管理,看似老生常谈,而真正掌握内存管理的核心其实并不简单.ARC/MRR以及“谁分配谁就负责释放”这种基本原则是很重要的,但不是本文要讨论的重点.之前本人还没在小站发过相关的文章,本篇文章中,我本人是想结合实际开发和调试中遇到的一些细节问题,来谈谈iOS的内存管理内在机制和调试方法. 上一篇文章已经是4月份的了,时间飞快又过去了好久,小站5月份没有文章更新,罪过罪过.最近小站的站长我又转换

Cocos2d-x开发---关于内存检测

这几天面试的时候,面试官都会问我在游戏开发过程中是如何应对内存检测的,如何监控程序是否有内存泄漏的问题.在开发的过程中也没有认真的注意过这个问题(当然不是说不去关注程序的内存泄漏问题,而是说并没有特意到去思考如何去监控),因为上家公司使用的是xcode开发工具,其自带了性能监控的工具,平时也就是用的这个,可能没太在意这些吧. 因为面试官问这个比较多,然后我感觉自己确实需要多注意注意程序开发过程中的一些基础性问题,所以把自己所知道的整理整理. Mac上: 使用xcode进行开发,当运行模拟器或者进

【调试】Linux下超强内存检测工具Valgrind

[调试]Linux下超强内存检测工具Valgrind 内容简介 Valgrind是什么? Valgrind的使用 Valgrind详细教程 1. Valgrind是什么? Valgrind是一套Linux下,开放源代码(GPLV2)的仿真调试工具的集合.Valgrind由内核(core)以及基于内核的其他调试工具组成. 内核类似于一个框架(framework),它模拟了一个CPU环境,并提供服务给其他工具:而其他工具则类似于插件 (plug-in),利用内核提供的服务完成各种特定的内存调试任务.

EVC内存检测

将以下代码保存为.h文件,在待检测的应用中调用它. 1 /***************************************************************** 2 为了使用内存检测,需要在待检测代码中进行以下三步: 3 1. Define _DEBUG #define _DEBUG 4 2. Include "crtdbg.h" #include "crtdbg.h" 5 3. Let your first line in the co