博客
关于我
NSDateFormatter的替代方法
阅读量:794 次
发布时间:2023-02-17

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

hot3.png

NSDateFormatter的替代方法

频繁创建、初始化NSDateFormatter来转换时间比较耗性能,下面来做一个实验

////方法1:使用strptime方法转换时间//#include 
-(void)convertTime1:(NSString *)iso8601String{ time_t t; struct tm tm; strptime([iso8601String cStringUsingEncoding:NSUTF8StringEncoding], "%Y-%m-%d %H:%M:%S%z", &tm); tm.tm_isdst = -1; t = mktime(&tm); [NSDate dateWithTimeIntervalSince1970:t + [[NSTimeZone localTimeZone] secondsFromGMT]];}//方法2:使用NSDateFormatter转换时间-(void)convertTime2:(NSString *)iso8601String{ NSDateFormatter *formatter = [[NSDateFormatter alloc] init]; formatter.dateFormat = @"yyyy-MM-dd hh-mm-ss"; formatter.locale = [[NSLocale alloc] initWithLocaleIdentifier:@"zh_cn"]; NSDate *date = [self.formatter dateFromString:iso8601String];}//将以上连个方法执行10000次,比较消耗的时间 NSDate *date = [NSDate date]; for(int i = 0 ;i < 10000; i++){ [self convertTime1:iso8601String]; } NSLog(@"method 1:%f", [[NSDate date] timeIntervalSinceDate:date]); date = [NSDate date]; for(int i = 0 ;i < 10000; i++){ [self convertTime2:iso8601String]; } NSLog(@"method 2:%f", [[NSDate date] timeIntervalSinceDate:date]); 测试结果:2017-11-10 16:42:19.932013+0800 t[1337:395110] method 1:0.1288602017-11-10 16:42:23.252324+0800 t[1337:395110] method 2:3.319963可以看出使用NSDateFormatter耗费了大量的时间;
解决办法:

苹果官方给出的建议是将NSDateFormatter保存成单例,我们修改代码,将NSDateFormatter懒加载

-(NSDateFormatter *)formatter{    if(_formatter == nil){        _formatter = [[NSDateFormatter alloc] init];        _formatter.dateFormat = @"yyyy-MM-dd hh-mm-ss";        _formatter.locale = [[NSLocale alloc] initWithLocaleIdentifier:@"zh_cn"];    }        return _formatter;}-(void)convertTime1:(NSString *)iso8601String{    time_t t;    struct tm tm;    strptime([iso8601String cStringUsingEncoding:NSUTF8StringEncoding], "%Y-%m-%d %H:%M:%S%z", &tm);    tm.tm_isdst = -1;    t = mktime(&tm);    [NSDate dateWithTimeIntervalSince1970:t + [[NSTimeZone localTimeZone] secondsFromGMT]];    }-(void)convertTime2:(NSString *)iso8601String{    [self.formatter dateFromString:iso8601String];}测试结果:2017-11-10 16:45:06.865066+0800 t[1340:395974] method 1:0.1287382017-11-10 16:45:07.973324+0800 t[1340:395974] method 2:1.108044和修改之前进行比较,消耗的时间确实有所减少。

 

strptime 日期格式%a星期几的英语缩写Sun, Mon, ..., Sat(en_US); So, Mo, ..., Sa(de_DE) %A星期几的英语全称Sunday, Monday, ..., Saturday(en_US) %w星期几采用数字表示,0表示星期日,6表示星期六。0,1,...,6 %d用0补充的两位日期数字。01,02,...,31 %b月份采用缩写字符表示。Jan, Feb,..., Dec(en_US) %B月份采用全名称表示。January, February, ...,December(en_US) %m月份采用0补充的两位数表示。01,02,...,12 %y年份采用0补充的两位数表示。00,01,...,99 %Y采用四位数表示的年份。0001,0002,...,2013,2014,2015,...,9998,9999 %H以0补充的24小时表示的小时。00,01,...,23 %I以0补充的12小时表示的小时。00,01,...,12 %p本地时间是上午还是下午。AM,PM(en_US) %M以0补充的分钟表示。00,01,...,59 %S以0补充的秒表示。00,01,...,59 %f以0补充的微秒表示。000000,000001,...,999999 %zUTC偏移表示为+HHMM或-HHMM。(empty),+0000,-0400,+1030 %Z时区名称。(empty),UTC,EST,CST %j以0补充的年的天数。001,002,...,366 %U一年里第几周,星期日作为一周开始。00,01,...,53 %W一年里第几周,星期一作为一周开始。00,01,...,53 %c采用本地合适日期和时间表示。Tue Aug 16 21:30:00 1988(en_US) %x采用本地合适日期表示。08/16/88(None);08/16/1988(en_US) %%输出百分号%。%

参考

http://www.jianshu.com/p/c9d38a3b2fd6

https://www.cnblogs.com/tingxins/p/6021614.html

http://blog.csdn.net/caimouse/article/details/50198695

转载于:https://my.oschina.net/mexiaobai1315/blog/1571206

你可能感兴趣的文章
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>
mysql中的rbs,SharePoint RBS:即使启用了RBS,内容数据库也在不断增长
查看>>
mysql中的undo log、redo log 、binlog大致概要
查看>>
Mysql中的using
查看>>
MySQL中的关键字深入比较:UNION vs UNION ALL
查看>>
mysql中的四大运算符种类汇总20多项,用了三天三夜来整理的,还不赶快收藏
查看>>
mysql中的字段如何选择合适的数据类型呢?
查看>>
MySQL中的字符集陷阱:为何避免使用UTF-8
查看>>