博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Objective-C 计算代码运行时间
阅读量:4330 次
发布时间:2019-06-06

本文共 1693 字,大约阅读时间需要 5 分钟。

今天看到一篇关于iOS应用性能优化的文章,其中提到计算代码的运行时间,觉得非常有用,值得收藏。不过在模拟器和真机上是有差异的,以此方法观察程序运行状态,提高效率。

第一种:(最简单的NSDate)

NSDate* tmpStartData = [NSDate date];//You code here...double deltaTime = [[NSDate date] timeIntervalSinceDate:tmpStartData];NSLog(@"cost time = %f", deltaTime);

第二种:(将运行代码放入下面的Block中,返回时间)

#import 
// for mach_absolute_time() and friendsCGFloat BNRTimeBlock (void (^block)(void)) {mach_timebase_info_data_t info;if (mach_timebase_info(&info) != KERN_SUCCESS) return -1.0;uint64_t start = mach_absolute_time ();block ();uint64_t end = mach_absolute_time ();uint64_t elapsed = end - start;uint64_t nanos = elapsed * info.numer / info.denom;return (CGFloat)nanos / NSEC_PER_SEC;}

第三种:

/*** 计算脚本时间* @param $last 最后一次的运行clock* @param $key  标识* @return 当前clock*/double t(double last, char* key){clock_t now = clock();printf("time:%fs \t key:%s \n", (last != 0) ? (double)(now - last) / CLOCKS_PER_SEC : 0, key);return now;}double t1 = t(0, "");//do somethingt(t1, "end");

飘飘白云文中说到,对于UIImage载入图像的方法,下面第一种更为高效,因为iOS会自带 cache 载入图像。

+ (UIImage *)imageNamed:(NSString *)name;- (id)initWithContentsOfFile:(NSString *)path;

但是,imageNamed方法只能载入bundle中的文件,如网络图像解析就无能为力了。

正好这里总结到计算代码运行时间,就以此为例看看两种方法到底谁更高效,这里我用最简单的NSDate计算耗时:

for (int i=0 ; i<10000; i++) {UIImage *image = [UIImage imageNamed:@"icon.png"];//        UIImage *image = [[UIImage alloc] initWithContentsOfFile:@"icon.png"];image = nil;}double deltaTime = [[NSDate date] timeIntervalSinceDate:tmpStartData];NSLog(@"cost time = %f", deltaTime);

输出结果:

cost time = 0.022821 //imageNamedcost time = 0.102620 //initWithContentsOfFile

这里图片我用的一张1024x1024像素的png,可见两种加载图像的方法耗时差别还是挺大的。

部分引用自:

转载于:https://www.cnblogs.com/hanjian/p/4866405.html

你可能感兴趣的文章
小D课堂 - 新版本微服务springcloud+Docker教程_3-05 服务注册和发现Eureka Server搭建实战...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_3-06 服务注册和发现之Eureka Client搭建商品服务实战...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_3-07 Eureka服务注册中心配置控制台问题处理...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_4-01 常用的服务间调用方式讲解
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_4-02 微服务调用方式之ribbon实战 订单调用商品服务...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_4-03 高级篇幅之Ribbon负载均衡源码分析实战...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_4-06 Feign核心源码解读和服务调用方式ribbon和Feign选择...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_4-05 微服务调用方式之feign 实战 订单调用商品服务...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_5-02 Netflix开源组件断路器
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_5-01分布式核心知识之熔断、降级
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_5-04 feign结合hystrix断路器开发实战下...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_5-03 feign结合hystrix断路器开发实战上...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_6-01 微服务网关介绍和使用场景
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_5-05熔断降级服务异常报警通知
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_6-03 高级篇幅之zuul常用问题分析
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_5-08 断路器监控仪表参数
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_6-02 springcloud网关组件zuul
查看>>
小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_2-1.快速搭建SpringBoot项目,采用Eclipse...
查看>>
小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_1-4.在线教育后台数据库设计...
查看>>
小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_2-3.热部署在Eclipse和IDE里面的使用...
查看>>