数组,字典便利性能测试

2016-05-31  本文已影响214人  大兵布莱恩特

一 ) 数组便利那种方式效率更高 ,往数组里添加了10000个字符串,然后通过便利讲每个字符串到控制台输出

for (int i=0; i<10000; i++) {

NSString *string = @"111";

[self.array addObject:string];

}

01    for - in 便利10000次 耗时 2.555秒

for (NSString *string in self.array) {

NSLog(@"----%@",string);

}

02 for int i =0 ; i<self.array.count ; i++ 便利10000次 耗时 2.818秒 

for (int i=0; i<self.array.count ; i++ ) {

NSLog(@"----%@",self.array[i]);

}

03 enumerateObjectsUsingBlock NSArray 提供的方法进行便利 耗时 3.348秒 

[self.array enumerateObjectsUsingBlock:^(id  _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {

NSLog(@"----%@",obj);

}];

二 ) 对 NSDictionary 进行便利 ,往 dict 里边添加10000个元素,然后打印每个 object的值

01 根据 [dict allkeys] 便利所有key 取出对应的 value  耗时 2.223 秒

for (NSString *key in [self.dict allKeys]) {

id object = self.dict[key];

NSLog(@"----%@",object);

}

02 利用 NSDictionay 的 enumerateKeysAndObjectsUsingBlock 耗时 2.139 秒 

[self.dict enumerateKeysAndObjectsUsingBlock:^(id  _Nonnull key, id  _Nonnull obj, BOOL * _Nonnull stop) {

NSLog(@"----%@",obj);

}];

03 利用枚举器便利 耗时 3.031  秒

NSEnumerator *enumerator = [self.dict keyEnumerator];

id object;

while (object =[enumerator nextObject]) {

id objectValue = self.dict[object];

NSLog(@"\n--%@  \n",objectValue);

}   

04 利用系统的 enumerateKeysAndObjectsWithOptions 便利 1.168 秒 

[self.dict enumerateKeysAndObjectsWithOptions:NSEnumerationConcurrent usingBlock:^(id  _Nonnull key, id  _Nonnull obj, BOOL * _Nonnull stop) {

NSLog(@"----%@",obj);

}];

好了,我是大兵布莱恩特,欢迎加入博主技术交流群,iOS 开发交流群

![QQ20180712-0.png](https://img.haomeiwen.com/i1155481/9b84a3a3fce64f61.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

上一篇 下一篇

猜你喜欢

热点阅读