博客
关于我
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

你可能感兴趣的文章
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
【Flink】Flink 1.9 版本 web UI 突然没有日志
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_实际操作---大数据之Nifi工作笔记0020
查看>>