性能是苹果审核的一个很重要的部分,CPU,内存,图形绘制,存储空间和网络性能都是应用的重要的评估和组成部分。不管是作为个人应用开发者还是企业的开发人员,都需要遵循的一个原则是站在用户的角度去思考问题,比如说常见的适配问题,不能因为不同的机型导致最终出现的UI效果差异很大,用户在使用的过程的中最好不要表现出明显的卡顿现象,或者更严重的是出现App闪退,出现闪退的结果就是应用被删,这是属于比较严重的问题。Instruments是目前最强大的性能调试工具之一,有助于我们解决应用存在的性能问题。Instruments是里面包括了内存管理工作,I/O以及网络过去,本文主要讲述的是Allocation和Time Profle。

Allocations(内存分配)

调试之前,我们先来看一个效果图:

就是动态的将文字输出在视图上,下面贴出代码你会发现开始还好运行到慢的简直跟蜗牛有的一拼,不要运行太久,否则内存不够用,代码如下:

@implementation FETextView

- (id)initWithFrame:(CGRect)frame text:(NSString *)text {
self = [super initWithFrame:frame];
if (self) {
[NSTimer scheduledTimerWithTimeInterval:0.01 target:self selector:@selector(appendNextCharacter) userInfo:nil repeats:YES];
_text = [text copy];
self.backgroundColor = [UIColor whiteColor];
}
return self;
}
//原文地址:http://www.cnblogs.com/xiaofeixiang
- (void)appendNextCharacter {
for (NSUInteger i = 0; i <= self.index; i++) {
if (i < self.text.length) {
UILabel *label = [[UILabel alloc] init];
label.text = [self.text substringWithRange:NSMakeRange(i,1)];
label.opaque = NO;
[label sizeToFit];
CGRect frame = label.frame;
frame.origin = [self originAtIndex:i
fontSize:label.font.pointSize];
label.frame=frame;
[self addSubview:label];
}
}
self.index++;
} - (CGPoint)originAtIndex:(NSUInteger)index
fontSize:(CGFloat)fontSize {
if (index == 0) {
return CGPointZero;
}
else {
CGPoint origin = [self originAtIndex:index-1 fontSize:fontSize];
NSString *
prevCharacter = [self.text
substringWithRange:NSMakeRange(index-1,1)];
CGSize
prevCharacterSize = [prevCharacter
sizeWithAttributes:@{ NSFontAttributeName:
[UIFont systemFontOfSize:fontSize]
}];
origin.x += prevCharacterSize.width;
if (origin.x > CGRectGetWidth(self.bounds)) {
origin.x = 0;
origin.y += prevCharacterSize.height;
}
return origin;
}
}
@end

主视图控制器的调用代码:

    NSString *
path = [[NSBundle mainBundle] pathForResource:@"FlyElephant"
ofType:@"txt"]; FETextView *textView = [[FETextView alloc]
initWithFrame:CGRectMake(0, 64, CGRectGetWidth(self.view.bounds), CGRectGetHeight(self.view.bounds))
text:[NSString stringWithContentsOfFile:path
encoding:NSUTF8StringEncoding
error:nil]];
[self.view addSubview:textView];

这个时候我们通过Allocation可以进行内存分析,将Xcode切换为Release状态,通过Product→Profile(Cmd+i)找到Allocations:

1.红色的按钮是表示停止和启动应用程序,不要理解成了暂停,Objective-C所有的对象都是在堆上分配的,记得勾选一下All Heap  Allocations:

2.点击All  Heap  Allocation,勾选Call  Tree,同时不查看系统的函数库:

3.具体方法占用的内存,可以逐级点开,效果如下:

以上是常规的Allocations使用,关于第二张图的有框中的几个选项可以解释一下:

Separate by Thread: 每个线程应该分开考虑,考虑到应用程序中GCD的存在;
Invert Call Tree: 从上倒下跟踪堆栈,这意味着你看到的表中的方法,将已从第0帧开始取样,利用栈的先进后出的特性,我们可以在栈顶看到最近调用的函数;
Hide System Libraries: 勾选此项会显示app的代码,这是非常有用的;
Flatten Recursion: 递归函数, 每个堆栈跟踪一个条目;

Time Profiler

Time Profiler在Allocations的下方,如图所示:

1.Allocations可以更好查看占用的内存,Time Profiler可以更好查看时间:

2.点击消耗时间最多的originAtIndex方法,效果如下:

3.查看具体每一行代码的占用时间的百分比,点击Xcode的图标可以进入Xcode中查看代码:

关于Time  Profiler的基本用户大概就是这样,关于开发我们还有可能使用到Leak内存泄露工具,基本方法大同小异,关于内存泄露包括两种泄漏:

第一种内存泄漏是指生成的实例对象用完之后不被释放,就会造成内存无法被重新使用;

第二种内存泄漏是发生在内存继续分配形成循环引用,并永远不会有机会被释放;

iOS开发-Instruments性能调优的更多相关文章

  1. 测试开发mysql性能调优总结(一)

    测试开发mysql性能调优总结 mysql在创建表的时候,对每个字段选择合适的数据类型很重要! 根据个人的经验总结: 整数类型选择 INT小数类型选择 DECIMAL字符串类型选择 TEXT日期时间选 ...

  2. Instruments(性能调优 12.3)

    Instruments Instruments是Xcode套件中没有被充分利用的一个工具.很多iOS开发者从没用过Instruments,或者只是用Leaks工具检测循环引用.实际上有很多Instru ...

  3. iOS 之应用性能调优的25个建议和技巧

    注意:每在优化代码之前,你都要注意一个问题,不要养成"预优化"代码的错误习惯. 时常使用Instruments去profile你的代码来发现须要提升的方面.Matt Gallowa ...

  4. iOS开发25个性能调优技巧

    1. 用ARC管理内存 ARC(Automatic Reference Counting, 自动引用计数)和iOS5一起发布,它避免了最常见的也就是经常是由于我们忘记释放内存所造成的内存泄露.它自动为 ...

  5. IOS性能调优系列:使用Instruments动态分析内存泄漏

    硬广:<IOS性能调优系列>第二篇,持续更新,欢迎关注. 第一篇介绍了Analyze对App做静态分析,可以发现应用中的内存泄漏问题,对于有些内存泄漏情况通过静态分析无法解决的,可以通过动 ...

  6. iOS应用性能调优建议

    本文来自iOS Tutorial Team 的 Marcelo Fabri,他是Movile的一名 iOS 程序员.这是他的个人网站:http://www.marcelofabri.com/,你还可以 ...

  7. iOS应用性能调优的25个建议和技巧

    本文来自iOS Tutorial Team 的 Marcelo Fabri,他是Movile的一名 iOS 程序员.这是他的个人网站:http://www.marcelofabri.com/,你还可以 ...

  8. [转]iOS应用性能调优的25个建议和技巧

    写在前面 本文来自iOS Tutorial Team 的 Marcelo Fabri,他是Movile的一名 iOS 程序员.这是他的个人网站:http://www.marcelofabri.com/ ...

  9. iOS性能调优

    写在前面 本文来自iOS Tutorial Team 的 Marcelo Fabri,他是Movile的一名 iOS 程序员.这是他的个人网站:http://www.marcelofabri.com/ ...

随机推荐

  1. 21.python中的闭包和装饰器

    python中的闭包从表现形式上定义(解释)为:如果在一个内部函数里,对在外部作用域(但不是在全局作用域)的变量进行引用,那么内部函数就被认为是闭包(closure). 以下说明主要针对 python ...

  2. java 获取当前方法名

    String _thisMethodName = new Exception().getStackTrace()[0].getMethodName();// 获得当前的方法名

  3. [JSOI2015]最小表示

    题目大意:尽可能多地去掉一个有向无环图上的边,使得图的连通性不变. 思路:拓扑排序,然后倒序求出每个结点到出度为$0$的点的距离$d$,再倒序遍历每一个点$x$,以$d$为关键字对其出边降序排序,尝试 ...

  4. 应用通信-方案一:RestTemplate

    @RestController public class ClientController { @Autowired private LoadBalancerClient loadBalancerCl ...

  5. 在Eclipse添加Android兼容包( v4、v7 appcompat )(转)

    昨天添加Android兼容包,碰到了很多问题,在这里记录一下,让后面的路好走. 如何选择兼容包, 请参考Android Support Library Features(二) 一.下载Support ...

  6. 使用 Spring 2.5 注释驱动的 IoC 功能(转)

    基于注释(Annotation)的配置有越来越流行的趋势,Spring 2.5 顺应这种趋势,提供了完全基于注释配置 Bean.装配 Bean 的功能,您可以使用基于注释的 Spring IoC 替换 ...

  7. HDU 4815 Little Tiger vs. Deep Monkey(2013长春现场赛C题)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4815 简单的DP题. #include <stdio.h> #include <st ...

  8. sTM32 使用TIMx_CH1作为 Tx1F_ED 计数器时钟

    环境:iar arm 5.3 stm32f103vbt6 使用PA.8 外部输入10Mhz的方波.可从systick中断得到数据4. 4×5000(预分频值)×1000(tick中断时间)=20MHz ...

  9. c# SerialPort会出现“已关闭 Safe handle”的错误

    c# SerialPort使用时出现“已关闭 Safe handle”的错误我在开发SerialPort程序时出现了一个问题,在一段特殊的扫描代码的时候会出现“已关闭 Safe handle”的错误, ...

  10. CLR是如何被加载并工作的

    当运行Windows应用程序的时候,CLR总是默默地为服务着.CLR到底是如何被加载并运行呢? 首先,Microsoft专门为CLR定义了一个标准的COM接口. 安装某个版本的.NET Framewo ...