一、探究

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 格式却并没有什么影响。

二、文章

NSDateFormatter 性能测试

iOS NSDateFormatter性能的更多相关文章

  1. iOS程序性能优化

    iOS程序性能优化 一.初级 使用ARC进行内存管理 在iOS5发布的ARC,它解决了最常见的内存泄露问题.但是值得注意的是,ARC并不能避免所有的内存泄露.使用ARC之后,工程中可能还会有内存泄露, ...

  2. iOS应用性能调优的25个建议和技巧【转】

    转载自:http://blog.jobbole.com/37984/ 首页 最新文章 资讯 程序员 设计 IT技术 创业 在国外 营销 趣文 特别分享 更多 > - Navigation -  ...

  3. iOS 程序性能优化

    前言 转载自:http://www.samirchen.com/ios-performance-optimization/ 程序性能优化不应该是一件放在功能完成之后的事,对性能的概念应该从我们一开始写 ...

  4. 25条提高iOS App性能的技巧和诀窍

    25条提高iOS App性能的技巧和诀窍 当我们开发iOS应用时,好的性能对我们的App来说是很重要的.你的用户也希望如此,但是如果你的app表现的反应迟钝或者很慢也会伤害到你的审核. 然而,由于IO ...

  5. 【iOS Instrument性能优化集】

    iOS Instrument性能优化集 1.UIImage缓存取舍 在项目代码中看到大量使用如下代码: UIImage使用 在Main Thread中发现不同动画场景中Image IO 开销和耗时所占 ...

  6. iOS app性能优化的那些事

     iPhone上面的应用一直都是以流畅的操作体验而著称,但是由于之前开发人员把注意力更多的放在开发功能上面,比较少去考虑性能的问题,可能这其中涉及到objective-c,c++跟lua,优化起来相对 ...

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

    任何一个能在用户手机屏幕中占有一席之地的iOS app都包含3个关键因素:想法好.设计出色.性能卓越.本文将分享一些iOS应用性能调优的4个建议和技巧. Tip #1:把图片资源压缩到最小.    i ...

  8. [深入浅出Cocoa]iOS程序性能优化

    本文转载至 http://blog.csdn.net/kesalin/article/details/8762032 [深入浅出Cocoa]iOS程序性能优化 罗朝辉 (http://blog.csd ...

  9. 25条提高iOS App性能的建议和技巧

    这篇文章来自iOS Tutorial Team 成员 Marcelo Fabri, 他是 Movile 的一个iOS开发者. Check out his personal website or fol ...

随机推荐

  1. Html5 部分帮助文档 未完待续

     W3cSchoolH5帮助文档 Video属性 视频播放效果 Video标签 src视频得目录 controls属性提供添加 播放 和音量控件 当然呢 不设置宽和高得话 视频会很大 Video还可以 ...

  2. 【vue】---- v-model在自定义组件中的使用

    1. v-model简介 可以用 v-model 指令在表单 <input>.<textarea> 及 <select> 元素上创建双向数据绑定,它的本质是一个语法 ...

  3. 安装ArchLinux时遇到的部分问题

    目录 一.网络问题 1.安装刚开始时连接wifi 2.安装完桌面后 二.卸载gnome桌面 三.启动桌面(以kde桌面为例) 1.立即启动桌面(start , stop) 2.设置开启自启动 (ena ...

  4. flask 部署外部访问

    在 app.run(host='0.0.0.0',port=5000) 可以让外部客户端进行访问,访问地址是flask服务器的ip地址和你设置的端口(端口注意不要占用其他端口,如果是阿里云有可能要设置 ...

  5. css3 scale 缩放出现 1px 问题

    问题描述 先来一段html代码 <div class="container"> <div class="parent"> <div ...

  6. 写一个scrapy中间件--ip代理池

    middleware文件 # -*- coding: utf-8 -*- # Define here the models for your spider middleware # See docum ...

  7. 分布式框架Celery(转)

    一.简介 Celery是一个异步任务的调度工具. Celery 是 Distributed Task Queue,分布式任务队列,分布式决定了可以有多个 worker 的存在,队列表示其是异步操作,即 ...

  8. 在Centos系统中基于PowerDNS和Poweradmin自建域名解析服务器替代DnsPod

    本文讲述了我在Centos 7系统(其他版本的Centos未尝试)中基于PowerDNS和poweradmin自建域名解析服务器替代DnsPod的过程.通过本文所述方法,可以建立权威域名解析服务器的m ...

  9. 利用JDBC工具类添加和查询数据-Java(新手)

    JDBC工具类: 1 package cn.lxr.jdbclx; 2 3 import java.sql.*; 4 5 public class JDBCUtils { 6 private stat ...

  10. Callable的Future模式

    一.线程实现方式 1.继承Thread类 2.实现Runnable接口 3.线程池 4.Callable 二.无论使用继承Thread类还是实现Runnable接口,还是使用线程池都没有办法解决2个问 ...