iOS NSDateFormatter性能
一、探究
NSDateFormatter * dateFormatter = [[NSDateFormatter alloc] init];
[dateFormatter setDateFormat:@"yyyy-MM-dd"];
NSString * current = [dateFormatter stringFromDate:[NSDate date]];
关于 NSDateFormatter 创建耗时的资料很多,下面开始测试一下,究竟有多耗时。
double begin = 0.0;
double end = 0.0;
NSDateFormatter * formatter = nil;
{
begin = CACurrentMediaTime();
for (int i = 0; i < 1000; i++) {
formatter = [[NSDateFormatter alloc] init];
[formatter setDateFormat:@"yyyy-MM-dd"];
[formatter stringFromDate:[NSDate date]];
}
end = CACurrentMediaTime();
NSLog(@"NSDateFormatter: %8.2f ms", (end - begin) * 1000);
}
{
begin = CACurrentMediaTime();
formatter = [[NSDateFormatter alloc] init];
for (int i = 0; i < 1000; i++) {
[formatter setDateFormat:@"yyyy-MM-dd"];
[formatter stringFromDate:[NSDate date]];
}
end = CACurrentMediaTime();
NSLog(@"NSDateFormatter once: %8.2f ms", (end - begin) * 1000);
}
-----------Xcode 10.1 iPhone 6s(10.0)----------
2019-03-01 10:08:42.184 Demo[95118:1359994] NSDateFormatter: 48.73 ms
2019-03-01 10:08:42.188 Demo[95118:1359994] NSDateFormatter once: 3.57 ms
2019-03-01 10:11:18.871 Demo[95164:1361958] NSDateFormatter: 61.18 ms
2019-03-01 10:11:18.875 Demo[95164:1361958] NSDateFormatter once: 3.85 ms
2019-03-01 10:12:03.123 Demo[95178:1362677] NSDateFormatter: 79.80 ms
2019-03-01 10:12:03.129 Demo[95178:1362677] NSDateFormatter once: 6.08 ms
上面可以看出两者之间消耗时间差距很大。创建单例很有必要。
那是 [[NSDateFormatter alloc] init] 初始化消耗太高吗?
NSDateFormatter * formatter = nil;
double begin = 0.0;
double end = 0.0;
double a = 0, b = 0, c = 0;
for (int i = 0; i < 1000; i++) {
begin = CACurrentMediaTime();
formatter = [[NSDateFormatter alloc] init];
end = CACurrentMediaTime();
a += (end - begin);
begin = CACurrentMediaTime();
[formatter setDateFormat:@"yyyy-MM-dd"];
end = CACurrentMediaTime();
b += (end - begin);
begin = CACurrentMediaTime();
[formatter stringFromDate:[NSDate date]];
end = CACurrentMediaTime();
c += (end - begin);
}
NSLog(@"NSDateFormatter:alloc %8.2f ms", a * 1000);
NSLog(@"NSDateFormatter:setFormat %8.2f ms", b * 1000);
NSLog(@"NSDateFormatter:stringFromDate %8.2f ms", c * 1000);
-------------Xcode 10.1 iPhone 6s(10.0)-------------
2019-03-01 10:11:18.939 Demo[95164:1361958] NSDateFormatter:alloc 7.01 ms
2019-03-01 10:11:18.939 Demo[95164:1361958] NSDateFormatter:setFormat 0.28 ms
2019-03-01 10:11:18.939 Demo[95164:1361958] NSDateFormatter:stringFromDate 55.98 ms
2019-03-01 10:12:03.198 Demo[95178:1362677] NSDateFormatter:alloc 7.69 ms
2019-03-01 10:12:03.199 Demo[95178:1362677] NSDateFormatter:setFormat 0.25 ms
2019-03-01 10:12:03.199 Demo[95178:1362677] NSDateFormatter:stringFromDate 60.97 ms
2019-03-01 10:18:43.946 Demo[95261:1366071] NSDateFormatter:alloc 6.01 ms
2019-03-01 10:18:43.946 Demo[95261:1366071] NSDateFormatter:setFormat 0.20 ms
2019-03-01 10:18:43.946 Demo[95261:1366071] NSDateFormatter:stringFromDate 49.06 ms
从上面可以看出,实际最耗时的方法是 stringFromDate:/dateFromString:。再往下细究。
double begin = 0.0;
double end = 0.0;
NSDateFormatter * formatter = [[NSDateFormatter alloc] init];
for (int i = 0; i < 1000; i++) {
[formatter setDateFormat:@"yyyy-MM-dd"];
begin = CACurrentMediaTime();
[formatter stringFromDate:[NSDate date]];
end = CACurrentMediaTime();
NSLog(@"%8.2f ms", (end - begin) * 1000);
}
-------------Xcode 10.0 iPhone 6s(10.0)-------------
2019-03-01 10:27:06.218 Demo[95456:1372764] 1.43 ms
2019-03-01 10:27:06.218 Demo[95456:1372764] 0.03 ms
2019-03-01 10:27:06.219 Demo[95456:1372764] 0.02 ms
2019-03-01 10:27:06.219 Demo[95456:1372764] 0.01 ms
2019-03-01 10:27:06.219 Demo[95456:1372764] 0.01 ms
2019-03-01 10:27:06.219 Demo[95456:1372764] 0.01 ms
2019-03-01 10:27:06.219 Demo[95456:1372764] 0.01 ms
2019-03-01 10:27:06.219 Demo[95456:1372764] 0.02 ms
2019-03-01 10:27:06.220 Demo[95456:1372764] 0.01 ms
2019-03-01 10:27:06.220 Demo[95456:1372764] 0.01 ms
2019-03-01 10:27:06.220 Demo[95456:1372764] 0.01 ms
2019-03-01 10:27:06.220 Demo[95456:1372764] 0.01 ms
2019-03-01 10:27:06.220 Demo[95456:1372764] 0.01 ms
2019-03-01 10:27:06.221 Demo[95456:1372764] 0.01 ms
2019-03-01 10:27:06.221 Demo[95456:1372764] 0.01 ms
从上面可以看出,只有首次调用 stringFromDate:/dateFromString: 方法才会很耗时。再往下细究。
还有人说应该针对 format 格式创建对应的单例对象。
double begin = 0.0;
double end = 0.0;
// 不同的对象不同的 format 格式
{
begin = CACurrentMediaTime();
NSDateFormatter * formatter1 = [[NSDateFormatter alloc] init];
NSDateFormatter * formatter2 = [[NSDateFormatter alloc] init];
NSDateFormatter * formatter3 = [[NSDateFormatter alloc] init];
NSDateFormatter * formatter4 = [[NSDateFormatter alloc] init];
for (int i = 0; i < 1000; i++) {
[formatter1 setDateFormat:@"yyyy-MM-dd"];
[formatter1 stringFromDate:[NSDate date]];
[formatter2 setDateFormat:@"MM-dd-yyyy"];
[formatter2 stringFromDate:[NSDate date]];
[formatter3 setDateFormat:@"MM-dd"];
[formatter3 stringFromDate:[NSDate date]];
[formatter4 setDateFormat:@"MM-yyyy"];
[formatter4 stringFromDate:[NSDate date]];
}
end = CACurrentMediaTime();
printf("NSDateFormatter: different format %8.2f ms\n", (end - begin) * 1000);
}
// 同一个对象不同的 format 格式
{
begin = CACurrentMediaTime();
NSDateFormatter * formatter = [[NSDateFormatter alloc] init];
for (int i = 0; i < 1000; i++) {
[formatter setDateFormat:@"yyyy-MM-dd"];
[formatter stringFromDate:[NSDate date]];
[formatter setDateFormat:@"MM-dd-yyyy"];
[formatter stringFromDate:[NSDate date]];
[formatter setDateFormat:@"MM-dd"];
[formatter stringFromDate:[NSDate date]];
[formatter setDateFormat:@"MM-yyyy"];
[formatter stringFromDate:[NSDate date]];
}
end = CACurrentMediaTime();
printf("NSDateFormatter: %8.2f ms\n", (end - begin) * 1000);
}
---------------Xcode 10.1 iPhone 6s(10.0)---------------
NSDateFormatter: different format 23.26 ms
NSDateFormatter: 16.25 ms
如果不计 NSDateFormatter 对象的初始化时间,那么打印输出:
NSDateFormatter:different format 23.81 ms
NSDateFormatter: 23.02 ms
两者相差不大,创建一个单例即可。dateFormatter 初次使用时消耗较大,设置 format 格式却并没有什么影响。
二、文章
iOS NSDateFormatter性能的更多相关文章
- iOS程序性能优化
iOS程序性能优化 一.初级 使用ARC进行内存管理 在iOS5发布的ARC,它解决了最常见的内存泄露问题.但是值得注意的是,ARC并不能避免所有的内存泄露.使用ARC之后,工程中可能还会有内存泄露, ...
- iOS应用性能调优的25个建议和技巧【转】
转载自:http://blog.jobbole.com/37984/ 首页 最新文章 资讯 程序员 设计 IT技术 创业 在国外 营销 趣文 特别分享 更多 > - Navigation - ...
- iOS 程序性能优化
前言 转载自:http://www.samirchen.com/ios-performance-optimization/ 程序性能优化不应该是一件放在功能完成之后的事,对性能的概念应该从我们一开始写 ...
- 25条提高iOS App性能的技巧和诀窍
25条提高iOS App性能的技巧和诀窍 当我们开发iOS应用时,好的性能对我们的App来说是很重要的.你的用户也希望如此,但是如果你的app表现的反应迟钝或者很慢也会伤害到你的审核. 然而,由于IO ...
- 【iOS Instrument性能优化集】
iOS Instrument性能优化集 1.UIImage缓存取舍 在项目代码中看到大量使用如下代码: UIImage使用 在Main Thread中发现不同动画场景中Image IO 开销和耗时所占 ...
- iOS app性能优化的那些事
iPhone上面的应用一直都是以流畅的操作体验而著称,但是由于之前开发人员把注意力更多的放在开发功能上面,比较少去考虑性能的问题,可能这其中涉及到objective-c,c++跟lua,优化起来相对 ...
- iOS应用性能调优的4个建议和技巧
任何一个能在用户手机屏幕中占有一席之地的iOS app都包含3个关键因素:想法好.设计出色.性能卓越.本文将分享一些iOS应用性能调优的4个建议和技巧. Tip #1:把图片资源压缩到最小. i ...
- [深入浅出Cocoa]iOS程序性能优化
本文转载至 http://blog.csdn.net/kesalin/article/details/8762032 [深入浅出Cocoa]iOS程序性能优化 罗朝辉 (http://blog.csd ...
- 25条提高iOS App性能的建议和技巧
这篇文章来自iOS Tutorial Team 成员 Marcelo Fabri, 他是 Movile 的一个iOS开发者. Check out his personal website or fol ...
随机推荐
- 《自拍教程36》段位三_Python面向对象类
函数只能面向过程,来回互相调用后顺序执行, 简单的编码项目,还能应付的过来, 复杂的大型项目,调用多了,就会乱. 如何才能不乱呢,可尝试下, 面向对象类的概念, 将现实世界的事物抽象成对象,将现实世界 ...
- p标签内不能嵌套块级标签
今天突然发现一个问题,那就是p标签内不能嵌套块级标签 例如: <p><p></p></p> 会被浏览器解析成 我又把 div 嵌套在里面,发现还是这样 ...
- 生产要不要开启MySQL查询缓存
一.前言 在当今的各种系统中,缓存是对系统性能优化的重要手段.MySQL Query Cache(MySQL查询缓存)在MySQL Server中是默认打开的,但是网上各种资料以及有经验的DBA都建议 ...
- 它的JS与HTML标签是分离的吗
一个单的利用JS切换图片的功能写法1: <section> <h2>JS切换图片</h2> <ul class="pictable"> ...
- Flutter 拖拽排序组件 ReorderableListView
注意:无特殊说明,Flutter版本及Dart版本如下: Flutter版本: 1.12.13+hotfix.5 Dart版本: 2.7.0 ReorderableListView是通过长按拖动某一项 ...
- 必备技能三、render渲染函数
Vue 推荐使用在绝大多数情况下使用 template 来创建你的 HTML.然而在一些场景中,你真的需要 JavaScript 的完全编程的能力,这就是 render 函数,它比 template ...
- 什么是RPM
RPM是RedHat Package Manager(RedHat软件包管理工具)的缩写,这一文件格式名称虽然打上了RedHat的标志,但是其原始设计理念是开放式的,现在包括OpenLinux.S.u ...
- 项目团队测试改进&产品测试方法的思考和改进
七月份了,2019年已过去一半: 后半年,我们要以什么样的成果来对生命唱赞歌? 我目前负责公司一个小产品线的测试,和一个大产品线的项目测试. 产品测试,我才加入3周: 经过这段时间断断续续的磨合,我对 ...
- Python - 函数形参之必填参数、缺省参数、可变参数、关键字参数的详细使用
Python函数形参 必传参数:平时最常用的,必传确定数量的参数 缺省参数:在调用函数时可以传也可以不传,如果不传将使用默认值 可变参数:可变长度参数 关键字参数:长度可变,但是需要以kv对形式传参 ...
- linux入门系列19--数据库管理系统(DBMS)之MariaDB
前面讲完Linux下一系列服务的配置和使用之后,本文简单介绍一款数据库管理系统(MySQL的兄弟)MariaDB. 如果你有MySQL或其他数据的使用经验,MariaDB使用起来将非常轻松. 本文讲解 ...